在Oralce里,一个sql语句执行时会生成很多信息:
创新互联公司是一家集网站建设,平阳企业网站建设,平阳品牌网站建设,网站定制,平阳网站建设报价,网络营销,网络优化,平阳网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
SQL唯一标识
SQL文本信息
绑定变量信息
执行计划和游标信息
统计信息
性能信息
其他信息.例如sql来源,状态等
SQL_ID
在Oracle中,SQL优化器是负责解析sql的(包括直接执行的sql和存储过程中的sql),中的sql在提交sql优化器解析前,会进行一些预处理,包括大小写,空格,注释的处理等。
select /*test*/* from scott.emp e where e.empno = 10; select /*test*/* from scott.emp e where e.empno = 10; select /*test*/* from scott.emp E where e.empno = 10;
select * from v$sql v where v.SQL_TEXT like '%/*test*/%';
可以看到如果两个sql文本之间只要有任何的不同,就会生成不同的sql_id
分静态sql和动态sql两种,动态sql和第一种直接执行的sql一样,我们关注一下静态sql
declare v number; begin select /*+test1*/e.sal into v from scott.emp e where e.empno = 7369; select /*+test1*/e.sal into v from scott.emp e where e.empno = 7369; select /*+test1*/e.sal into v from scott.emp E where e.empno = 7369; end; /
执行后,查询sql信息,这里应该使用提示/*+xxx*/,注释会被过滤掉
从图中可以看出,三个sql语句只生成了一个sql_id,说明plsql提交到sql优化器的时候做了一些预处理。
declare v dbms_sql.Number_Table; xx number; begin v(1) := 7369; v(1) := 7499; v(1) := 7521; for i in v.first .. v.last loop select /*+test2*/e.sal into xx from scott.emp e where e.empno = v(i); end loop; end; /
我们看到也是只有一条sql语句的sql_id信息。e.empno = v(i) 被替换成了 绑定变量:B,当sql被提交到内存执行的时候,才会替换为具体的值并执行返回结果。
Copyright © 2009-2022 www.wtcwzsj.com 青羊区广皓图文设计工作室(个体工商户) 版权所有 蜀ICP备19037934号