oracle之SQL_ID 1
在Oralce里,一个sql语句执行时会生成很多信息:
SQL_ID 在Oracle中,SQL优化器是负责解析sql的(包括<a>直接执行的sql和<b>存储过程中的sql),<b>中的sql在提交sql优化器解析前,会进行一些预处理,包括大小写,空格,注释的处理等。 在解析sql时,sql优化器会分配一个ID(子游标),唯一标识一个sql(存储在v$sql视图内)。相同的sql文本sql_id是一样的(对应v$sqlarea中的数据,称它为父游标),即使是不同的数据库实例中,这个以后在介绍。其他视图通过这个id引用这个sql,在9i中对应的是hash_value这个字段,11g中v$sql有字段old_hash_value对应9i的hash_value,sql_id和hash_value是通过一定的算法计算出来的。 1.直接执行的sql: 在sql_window下执行 select/*test*/*fromscott.empewheree.empno=10; select/*test*/*fromscott.empewheree.empno=10; select/*test*/*fromscott.empEwheree.empno=10; 查询他们的sql信息 select*fromv$sqlvwherev.SQL_TEXTlike'%/*test*/%'; 可以看到如果两个sql文本之间只要有任何的不同,就会生成不同的sql_id 2.存储过程中的sql: 分静态sql和动态sql两种,动态sql和第一种直接执行的sql一样,我们关注一下静态sql declare vnumber; begin select/*+test1*/e.salintovfromscott.empewheree.empno=7369; select/*+test1*/e.salintovfromscott.empewheree.empno=7369; select/*+test1*/e.salintovfromscott.empEwheree.empno=7369; end; / 执行后,查询sql信息,这里应该使用提示/*+xxx*/,注释会被过滤掉 从图中可以看出,三个sql语句只生成了一个sql_id,说明plsql提交到sql优化器的时候做了一些预处理。 如果使用绑定变量呢?我们来看看有什么变化 declare vdbms_sql.Number_Table; xxnumber; begin v(1):=7369; v(1):=7499; v(1):=7521; foriinv.first..v.lastloop select/*+test2*/e.salintoxxfromscott.empewheree.empno=v(i); endloop; end; / 我们来看看sql_id情况 我们看到也是只有一条sql语句的sql_id信息。e.empno = v(i) 被替换成了 绑定变量:B,当sql被提交到内存执行的时候,才会替换为具体的值并执行返回结果。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |