博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle SQL : delete from (query), delete which table's row?
阅读量:6278 次
发布时间:2019-06-22

本文共 4371 字,大约阅读时间需要 14 分钟。

今天群里面一位朋友问了一个问题如下 :
DELETE FROM                                 (SELECT * FROM EPAD_MENU EM, MSG_DESC MD                                 WHERE MD.MD_TABLE = 'epad_menu' AND MD.MD_FIELD = 'em_id'                                 AND MD.MD_VALUE = EM.EM_ID AND EM.EM_BOOK_CODE = 'aa')
为什么删除的是 MSG_DESC的数据?

于是找了个测试库测试一下 :
SQL> create table t1(id int primary key,info varchar2(10));Table created.SQL> create table t2(id int primary key,info varchar2(10));Table created. SQL> insert into t1 values (1,'digoal');1 row created.SQL> insert into t1 values (2,'digoal');1 row created.SQL> insert into t2 values (1,'digoal');1 row created.SQL> insert into t2 values (2,'digoal');1 row created.SQL> commit;Commit complete.
下面来写个类似的delete语句 :
SQL> delete from (select * from t1,t2 where t1.id=1 and t2.id=t1.id and t2.info='digoal');1 row deleted.SQL> select * from t2;        ID INFO---------- ----------         1 digoal         2 digoalSQL> select * from t1;        ID INFO---------- ----------         2 digoal
把t1.数据删了, t2的没有动.

下面把t1和t2的顺序换一下 :
SQL> rollback;Rollback complete.SQL> delete from (select * from t2,t1 where t1.id=1 and t2.id=t1.id and t2.info='digoal');1 row deleted.SQL> select * from t1;        ID INFO---------- ----------         2 digoal         1 digoalSQL> select * from t2;        ID INFO---------- ----------         2 digoalSQL> rollback;
结果把t2的数据删了, t1没动.

来从执行计划看看是啥原因 :
SQL> explain plan for delete from (select * from t2,t1 where t1.id=1 and t2.id=t1.id and t2.info='digoal');Explained.SQL> select * from table(dbms_xplan.display);PLAN_TABLE_OUTPUT--------------------------------------------------------------------------------------------------------------------------------------------Plan hash value: 1934688782----------------------------------------------------------------------------------------------| Id  | Operation                     | Name         | Rows  | Bytes | Cost (%CPU)| Time     |----------------------------------------------------------------------------------------------|   0 | DELETE STATEMENT              |              |     1 |    33 |     1   (0)| 00:00:01 ||   1 |  DELETE                       | T2           |       |       |            |          ||   2 |   NESTED LOOPS                |              |     1 |    33 |     1   (0)| 00:00:01 ||*  3 |    TABLE ACCESS BY INDEX ROWID| T2           |     1 |    20 |     1   (0)| 00:00:01 ||*  4 |     INDEX UNIQUE SCAN         | SYS_C0065664 |     1 |       |     1   (0)| 00:00:01 ||*  5 |    INDEX UNIQUE SCAN          | SYS_C0065663 |     1 |    13 |     0   (0)| 00:00:01 |----------------------------------------------------------------------------------------------Predicate Information (identified by operation id):---------------------------------------------------   3 - filter("T2"."INFO"='digoal')   4 - access("T2"."ID"=1)   5 - access("T1"."ID"=1)19 rows selected.SQL> explain plan for delete from (select * from t1,t2 where t1.id=1 and t2.id=t1.id and t2.info='digoal');Explained.SQL> select * from table(dbms_xplan.display);PLAN_TABLE_OUTPUT--------------------------------------------------------------------------------------------------------------------------------------------Plan hash value: 2064908203----------------------------------------------------------------------------------------------| Id  | Operation                     | Name         | Rows  | Bytes | Cost (%CPU)| Time     |----------------------------------------------------------------------------------------------|   0 | DELETE STATEMENT              |              |     1 |    33 |     2   (0)| 00:00:01 ||   1 |  DELETE                       | T1           |       |       |            |          ||   2 |   NESTED LOOPS                |              |     1 |    33 |     2   (0)| 00:00:01 ||*  3 |    INDEX UNIQUE SCAN          | SYS_C0065663 |     1 |    13 |     1   (0)| 00:00:01 ||*  4 |    TABLE ACCESS BY INDEX ROWID| T2           |     1 |    20 |     1   (0)| 00:00:01 ||*  5 |     INDEX UNIQUE SCAN         | SYS_C0065664 |     1 |       |     0   (0)| 00:00:01 |----------------------------------------------------------------------------------------------Predicate Information (identified by operation id):---------------------------------------------------   3 - access("T1"."ID"=1)   4 - filter("T2"."INFO"='digoal')   5 - access("T2"."ID"=1)19 rows selected.

转载地址:http://fnbva.baihongyu.com/

你可能感兴趣的文章
物联网如何跳出“看起来很美”?
查看>>
浅谈MySQL 数据库性能优化
查看>>
《UNIX/Linux 系统管理技术手册(第四版)》——1.10 其他的权威文档
查看>>
灵动空间 创享生活
查看>>
《UNIX网络编程 卷1:套接字联网API(第3版)》——8.6 UDP回射客户程序:dg_cli函数...
查看>>
不要将时间浪费到编写完美代码上
查看>>
《第一桶金怎么赚——淘宝开店创业致富一册通》一一第1章 创业梦想,怎样起步...
查看>>
基于容器服务的持续集成与云端交付(三)- 从零搭建持续交付系统
查看>>
《算法基础:打开算法之门》一3.4 归并排序
查看>>
高德开放平台开放源代码 鼓励开发者创新
查看>>
《高并发Oracle数据库系统的架构与设计》一2.5 索引维护
查看>>
《Exchange Server 2010 SP1/SP2管理实践》——2.4 部署外部网络环境
查看>>
Firefox 是 Pwn2own 2014 上攻陷次数最多的浏览器
查看>>
阿里感悟(十八)- 应届生Review
查看>>
《计算广告:互联网商业变现的市场与技术》一第一部分 在线广告市场与背景...
查看>>
话说模式匹配(5) for表达式中的模式匹配
查看>>
《锋利的SQL(第2版)》——1.7 常用函数
查看>>
《Arduino家居安全系统构建实战》——1.5 介绍用于机器学习的F
查看>>
jquery中hover()的用法。简单粗暴
查看>>
线程管理(六)等待线程的终结
查看>>