在实践中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高,引发共享池栓锁等问题。
更多内容请关注公众号“测试小号等闲之辈”~