码迷,mamicode.com
首页 > 数据库 > 详细

oracle 存储过程 调用动态sql

时间:2018-08-16 13:31:57      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:head   exp   get   sed   http   html   body   推荐   into   

oracle 存储过程 调用动态sql

CreationTime--2018年8月16日11点25分

Author:Marydon

1.错误实现方式

--开始时间拼接‘ 00:00:00‘
  V_SQL := ‘select decode(length(‘ || V_END || ‘),10,‘ || ‘concat(‘ || V_END || ‘, 00:00:00),‘ || V_END || ‘) from dual‘;
  EXECUTE IMMEDIATE V_SQL;

  编译成功,但是存储过程调用失败。

技术分享图片

2.原因分析

  在oracl数据库中,ddl表示数据库定义语言,即我们平常使用的sql语句,声明的sql语句可以直接使用拼接字符串进行拼接;

  dml表示数据操纵语言,声明的sql语句不能再用管道符||来动态拼接变量。 

3.正确实现方式

  execute immediate属于dml,dml使用sql的规则如下:

  声明sql语句

  字符串拼接变量时,变量要使用占位符来代替,格式为 ":" + "名字",名字随意

  调用sql语句

  使用"using"来传递变量,代替占位符,格式为 "using var1,var2,..."

V_SQL := ‘select decode(length(:v1),10,:v2,:v3) from dual‘;
EXECUTE IMMEDIATE V_SQL INTO V_START USING V_START,V_START || ‘ 00:00:00‘,V_START;  

  结果展示:

技术分享图片 

4.测试

  入参

技术分享图片

  出参

技术分享图片

5.最简单的方式

--结束时间拼接‘ 00:00:00‘
SELECT DECODE(LENGTH(V_END), 10, V_END || ‘ 00:00:00‘, V_END) INTO V_END FROM DUAL;

 

oracle 存储过程 调用动态sql

标签:head   exp   get   sed   http   html   body   推荐   into   

原文地址:https://www.cnblogs.com/Marydon20170307/p/9486324.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!