oracle变量绑定.docVIP

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
oracle变量绑定

oracle变量绑定 DB层代码,发现SQL语句多采用常量形式,难怪公司总抱怨系统效率低。我知道采用绑定变量可以很大程度上提高效率,但却解释不清,到网上百度了一下,找到这篇文章,写的还不错,就摘录下来。以备以后参考。 ******************************************************************************* 在JAVA?源程序中编写SQL语句时使用ORACLE?绑定变量 ?bind?variable? 在JAVA中的SQL?语句的编写方面,没有使用ORACLE?绑定变量,很大程度上降低了数据库的性能,表现在两个方面: 1、SQL语句硬分析 Hard?Parse 太多,严重消耗CPU资源,延长了SQL语句总的执行时间SQL语句的执行过程分几个步骤:语法检查、分析、执行、返回结果。其中分析又分为硬分析 Hard?Parse 和软分析 Soft?Parse 。 一条SQL语句通过语法检查后,Oracle?会先去shared?pool?中找是否有相同的sql,如果找着了,就叫软分析,然后执行SQL语句。 硬分析主要是检查该sql所涉及到的所有对象是否有效以及权限等关系,然后根据RBO或CBO模式生成执行计划,然后才执行SQL语句。 可以看出,硬分析比软分析多了很多动作,而这里面的关键是“在shared?pool?中是否有相同的sql”,而这就取决于是否使用绑定变量。 2、共享池中SQL语句数量太多,重用性极低,加速了SQL语句的老化,导致共享池碎片过多。 共享池中不同的SQL语句数量巨大,根据LRU原则,一些语句逐渐老化,最终被清理出共享池;这样就导致shared_pool_size?里面命中率下降,共享池碎片增多,可用内存空间不足。而为了维护共享池内部结构,需要使用latch,一种内部生命周期很短的lock,这将使用大量的cpu?资源,使得性能急剧下降。不使用绑定变量违背了oracle?的shared?pool?的设计的原则,违背了这个设计用来共享的思想。 编写java?程序时,我们习惯都是定义JAVA?的程序变量,放入SQL?语句中,如 String?v_id? ?xxxxx; String?v_sql? ?select?name?from?table_a?where?id? ??+?v_id?;? 以上代码,看起来是使用了变量v_id?,但这却是java?的程序变量,而不是oracle?的绑定变量,语句传递到数据库后,此java?的程序变量已经被替换成具体的常量值,变成: select?*?from?table_a?where?name? ?xxxxx?; 假定这个语句第一次执行,会进行硬分析。后来,同一段java?代码中v_id?值发现变化(v_id? ?yyyyyy),数据库又接收到这样的语句: select?*?from?table_a?where?name? ?yyyyyy?; ORACLE?并不认为以上两条语句是相同的语句,因此对第二条语句会又做一次硬分析。这两条语句的执行计划可是一样的! 其实,只需将以上java?代码改成以下这样,就使用了oracle?的绑定变量: String?v_id? ?xxxxx; String?v_sql? ?select?name?from?table_a?where?id ;?//嵌入绑定变量 stmt? ?con.prepareStatement ?v_sql? ; stmt.setString 1,?v_id? ;?//为绑定变量赋值 stmt.executeQuery ; 在Java中,结合使用setXXX?系列方法,可以为不同数据类型的绑定变量进行赋值,从而大大优化了SQL?语句的性能。 如下例子演示了三种查询所花费的时间: 1.??不使用绑定变量 declare ?type?rc?is?ref?cursor; ?? l_rc rc; ?? l_dummy all_objects.object_name%type; ?? l_start?number?default?dbms_utility.get_time; ?begin ?for?i?in?1?..?1000 ???loop ?open?l_rc?for ???select object_name from all_objects where object_id ?|| i; ?fetch?l_rc?into?l_dummy; ?close?l_rc; ?end?loop; dbms_output.put_line round dbms_utility.get_time-l_start /100,?2? || seconds...? ; ?

文档评论(0)

peain + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档