CREATE OR REPLACE PROCEDURE INSERTAMOUNTTEST(v_region_code IN varchar2) IS
BEGIN
declare
v_sql varchar2(33);
begin
v_sql := 'update aaa set x =112 where region_code = 571';
[color=red] -- v_sql2 := 'update aaa set x = 6 where region_code = '''||v_region_code||'''';
-- v_sql3 := 'update aaa set x = 4 where region_code = '||v_region_code;[/color]
execute immediate v_sql;
commit;
end;
commit;
EXCEPTION
WHEN OTHERS THEN
commit;
END;
aaa表就是两个字段,一个number类型的x,还有一个varchar类型的region_code
上面我定义的三个v_sql任何一个都更新不了,execute immediate v_sql;没有执行就进入了异常块,实在不知道是为什么,谢谢,还有我想问下 v_sql2写法后面4个单引号还有前面3个单引号对吗