绑定变量:using → 只需要解析一次;
BEGIN
EXECUTE IMMEDIATE
'update emp set sal=sal*2 where empno=:p_empno' USING &p_eno;
COMMIT;
END;
注意:不能使用绑定变量替换实际的数据库对象名(表,视图,列等),只能替换字面量,
如果对象名是在运行时生成的,我们仍然需要对其用字符串拼接,同时,sql只会匹配已经
在共享池中相同的对象名
在动态sql中使用绑定变量和不使用绑定变量的性能测试(在测试表中添加10000条记录):
--创建测试表demo;
DROP TABLE demo;
CREATE TABLE demo(d_id NUMBER(6) PRIMARY KEY);
SELECT * FROM demo;
--1.不使用绑定变量
DECLARE
begin_time NUMBER(10);
end_time NUMBER(10);
BEGIN
begin_time := dbms_utility.get_time;
EXECUTE IMMEDIATE
'truncate table demo';
FOR i IN 1..10000
LOOP
EXECUTE IMMEDIATE
'INSERT INTO demo(d_id) VALUES('||i||')';
END LOOP;
end_time :=dbms_utility.get_time;
dbms_output.put_line((en