xuhang1128 2011-05-11 02:01
浏览 273
已采纳

请问一个存储过程execute immediate的问题

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个单引号对吗

  • 写回答

5条回答 默认 最新

  • iteye_8576 2011-05-11 13:04
    关注

    [color=red]请问v_region_code后面的4个单引号代表什么意思啊[/color]

    表示含有一个单引号(')的字符串

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置