- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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...? ;?
您可能关注的文档
- 数学区材料投放的方法.doc
- 数学三维设计答案.doc
- 闫糖尿病教案.doc
- 数学应用软件综合实验.doc
- 闸北高考补习班高三物理__功和功率习题新王牌.doc
- 数学建模-B题食堂就餐问题.doc
- 闽教版小学英语四年级上册教案.doc
- 阀门检修规程.doc
- 阅读作文辅导教案.doc
- MIS与SCADA系统接口.doc
- 2023-2024学年广东省深圳市龙岗区高二(上)期末物理试卷(含答案).pdf
- 2023-2024学年贵州省贵阳市普通中学高一(下)期末物理试卷(含答案).pdf
- 21.《大自然的声音》课件(共45张PPT).pptx
- 2023年江西省吉安市吉安县小升初数学试卷(含答案).pdf
- 2024-2025学年广东省清远市九校联考高一(上)期中物理试卷(含答案).pdf
- 广东省珠海市六校联考2024-2025学年高二上学期11月期中考试语文试题.pdf
- 2024-2025学年语文六年级上册第4单元-单元素养测试(含答案).pdf
- 2024-2025学年重庆八中高三(上)月考物理试卷(10月份)(含答案).pdf
- 安徽省安庆市潜山市北片学校联考2024-2025学年七年级上学期期中生物学试题(含答案).pdf
- 贵州省部分校2024-2025学年九年级上学期期中联考数学试题(含答案).pdf
文档评论(0)