oracle数据库未使用绑定变量性能问题

在实践中ORACLE数据库sql语句未使用绑定变量(出现未绑定变量的SQL数目)会引发性能问题。

       通常相关指标为未绑定变量SQL以不同值执行大于10次。

      绑定变量是指sql中对变化的值采用变量参数的形式提交,而不是在sql中直接拼写对应的值。

     绑定变量的优点:

       (1)防止sql注入

       (2)提高sql的可读性

       (3)提高sql的解析性能。

      不采用绑定变量,采用字符串拼接的模式生成sql,那么每条sql都会产生执行计划,会导致共享池耗尽,缓存命中率也很低。

     使用绑定变量时,不同session提交的SQL数据库会识别为同一个SQL,可以共享使用SQL执行计划,不必每次进行硬解析编译,有助于降低CPU的使用,避免Shared pool的碎片化,减少ORA-4031错误触发概率,便于SQL的管理、优化。

注意事项:

1、SQL过滤条件中该字段的输入值非常多,但分布通常较为均匀,常见如:账户号、姓名、时间等字段。

2、字段过滤条件使用Like时,不得使用绑定变量,应该给数据库明确的字段信息。由于Like返回的记录数可能很多也可能很少,数据库很有可能无法选择合适的执行计划。

3、使用绑定变量需注意变量长度、变量类型的匹配,如变量长度超过2000、类型不一致会存在触发SQL version_count高,引发共享池栓锁等问题。

更多内容请关注公众号“测试小号等闲之辈”~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值