oracle绑定变量与非绑定变量比较

本文通过两个案例对比展示了在Oracle数据库中使用绑定变量相较于非绑定变量能显著提高查询效率。使用绑定变量可以避免重复编译相同的SQL语句,从而节省了大量的分析、限定及优化等过程的时间。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

案例演示前准备工作:

--alter system flush shared_pool;
--set timing on;
--从一个“空”的共享池开始,如果多次运营这些测试语句,就需要每次清空共享池,否则,非绑定变量sql将被缓存,这样看起来运行非常快

----案例--使用非绑定变量
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...');
end;
/

 

----案例--使用绑定变量
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=:x' using 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...');
end;
/

 

 使用非绑定变量的明显比使用绑定变量的耗时长,原因在于:非绑定变量每次查询都是一个新的查询,即在数据库中以前没有过的查询。每次查询必须经过分析、限定(名称解析)、安全检查、优化等等;而使用绑定变量的查询,绑定变量的值在查询执行时提供。查询经过一次编译后,查询方案存储在共享池(库高速缓存)中,可以用来检索和重用,故二者的差异是巨大的。因此我们在实际工作中,应根据实际情况进行选择。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值