Mysql 5.0 以后,支持了动态sql语句,我们可以通过传递不同的参数得到我们想要的值

这里介绍两种在存储过程中的动态sql:

set sql = (预处理的sql语句,可以是用concat拼接的语句)

set @sql = sql

PREPARE stmt_nameFROM @sql;

EXECUTE stmt_name;

{DEALLOCATE | DROP} PREPARE stmt_name;

CREATE DEFINER = `root`@`%` PROCEDURE `NewProc`(IN `USER_ID` varchar(36),IN `USER_NAME` varchar(36))

BEGIN

declare SQL_FOR_SELECT varchar(500);                        -- 定义预处理sql语句

set SQL_FOR_SELECT = CONCAT("select * from user where user_id = '",USER_ID,"' and user_name = '",USER_NAME,"'"); -- 拼接查询sql语句

set @sql = SQL_FOR_SELECT;

PREPARE stmt FROM @sql; -- 预处理动态sql语句

EXECUTE stmt ; -- 执行sql语句

deallocate prepare stmt; -- 释放prepare

END;

上述是一个简单的查询用户表的存储过程,当我们调用此存储过程,可以根据传入不同的参数获得不同的值

但是:上述存储过程中,我们必须在拼接sql语句之前把USER_ID,USER_NAME定义好,而且在拼接sql语句之后,我们无法改变USER_ID,USER_NAME的值,如下

1 CREATE DEFINER = `root`@`%` PROCEDURE `NewProc`(IN `USER_ID` varchar(36),IN `USER_NAME` varchar(36))

2 BEGIN

3

4 declare SQL_FOR_SELECT varchar(500);                         -- 定义预处理sql语句

5

6 set SQL_FOR_SELECT = CONCAT("select * from user where user_id = '",USER_ID,"' and user_name = '",USER_NAME,"'"); -- 拼接查询sql语句

7

8 set @sql = SQL_FOR_SELECT;

9  PREPARE stmt FROM @sql; -- 预处理动态sql语句

10  EXECUTE stmt ; -- 执行sql语句

11 deallocate prepare stmt; -- 释放prepare

12

13

14 set USER_ID = '2';

15 set USER_NAME = 'lisi';

16

17 set @sql = SQL_FOR_SELECT;

18  PREPARE stmt FROM @sql; -- 预处理动态sql语句

19  EXECUTE stmt ; -- 执行sql语句

20 deallocate prepare stmt; -- 释放prepare

21 END;

我们用call aa('1','zhangsan');来调用该存储过程,第一次动态执行,我们得到了‘张三’的信息,然后我们在第14,15行将USER_ID,USER_NAME改为lisi,我们希望得到李四的相关信息,可查出来的结果依旧是张三的信息,说明我们在拼接sql语句后,不能再改变参数了。为了解决这种问题,下面介绍第二中方式

2.

set sql = (预处理的sql语句,可以是用concat拼接的语句,参数用 ?代替)

set @sql = sql

PREPARE stmt_nameFROM @sql;

set @var_name = xxx;

EXECUTE stmt_name USING [USING @var_name [, @var_name] ...];

{DEALLOCATE | DROP} PREPARE stmt_name;

上述的代码我们就可以改成

1 CREATE DEFINER = `root`@`%` PROCEDURE `NewProc`(IN `USER_ID` varchar(36),IN `USER_NAME` varchar(36))

2 BEGIN

3

4 declare SQL_FOR_SELECT varchar(500); -- 定义预处理sql语句

5

6 set SQL_FOR_SELECT = "select * from user where user_id = ? and user_name = ? ";                         -- 拼接查询sql语句

7

8 set @sql = SQL_FOR_SELECT;

9 PREPARE stmt FROM @sql;  -- 预处理动态sql语句

10

11 set @parm1 = USER_ID; -- 传递sql动态参数

12 set @parm2 = USER_NAME;

13

14 EXECUTE stmt USING @parm1 , @parm2;   -- 执行sql语句

15 deallocate prepare stmt; -- 释放prepare

16

17

18 set @sql = SQL_FOR_SELECT;

19 PREPARE stmt FROM @sql;   -- 预处理动态sql语句

20

21 set @parm1 = '2';    -- 传递sql动态参数

22 set @parm2 = 'lisi';

23

24 EXECUTE stmt USING @parm1 , @parm2;    -- 执行sql语句

25 deallocate prepare stmt; -- 释放prepare

26 END;

这样,我们就可以真正的使用不同的参数(当然也可以在存储过程中通过逻辑生成不同的参数)来使用动态sql了。

几个注意:

存储动态SQL的值的变量不能是自定义变量,必须是用户变量或者全局变量   如:set sql = 'xxx';  prepare stmt from sql;是错的,正确为: set @sql = 'xxx';  prepare stmt from @sql;

即使 preparable_stmt语句中的 ? 所代表的是一个字符串,你也不需要将 ? 用引号包含起来。

如果动态语句中用到了 in 则sql语句应该这样写:set @sql = "select * from user where user_id in (?,?,?) "

这里我也有个问题,因为有可能我不确定in语句里有几个参数,所以我试过这么写

set @sql = "select * from user where user_id in (?) "

然后参数我传的是  "'1','2','3'"  我以为程序会将我的动态sql解析出来(select * from user where user_id in ('1','2','3')) 但是并没有解析出来,各位大侠们帮帮忙,有什么好方法解决这个问题么?

mysql动态sql语句_mysql 存储过程中使用动态sql语句相关推荐

  1. mysql 存储过程 表名_MySql存储过程中执行动态SQL(表名是变量)

    项目中要显示每个表的记录条数,但是因为数据库中的索引表中(infomation_schema.tables)记录的每个表的数据条数不是那么实时(超过3w多就不准了),所以要手动持久化一下再显示,持久化 ...

  2. mysql 多个游标_mysql 存储过程中使用多游标

    mysql的存储过程可以很方便使用游标来实现一些功能,存储过程的写法大致如下: 先创建一张表,插入一些测试数据:DROP TABLE IF EXISTS netingcn_proc_test; CRE ...

  3. mysql存储过程是不是不能穿sql语句_mysql存储过程能不能直接执行拼接的sql语句...

    展开全部 当然可以,就是在mysql存储过程中使用动态sql,就可以拼接sql,然62616964757a686964616fe58685e5aeb931333361323562后执行了. 给你复制一 ...

  4. mysql存储过程into_MySQL存储过程中使用SELECT …INTO语句为变量赋值

    使用SELECT -INTO语句为变量赋值 在MySQL存储过程中,可以使用SELECT -INTO语句对变量进行赋值,该语句在数据库中进行查询,并将得到的结果赋值给变量.SELECT -INTO语句 ...

  5. 在存储过程中构建动态SQL

    目录 介绍 sp_executesql与EXECUTE命令 例1.0 例1.1 存储过程中的动态SQL 例2.0 在动态SQL中使用Like操作符,IN操作符和Order By 例3.0 - 使用LI ...

  6. mysql导出不带注释的sql语句_MySQL mysqlbinlog解析出的SQL语句被注释是怎么回事

    MySQL mysqlbinlog解析出的SQL语句被注释是怎么回事 一网友反馈使用mysqlbinlog解析出的二进制日志中的内容中,有些SQL语句有#注释的情况,这个是怎么回事呢?我们通过实验来了 ...

  7. sql server根据表中数据生成insert语句

    sql server根据表中数据生成insert语句 -- ====================================================== --根据表中数据生成inser ...

  8. SQL Server应用程序中的高级SQL注入[转]

    SQL Server应用程序中的高级SQL注入[从A.Z的POST里转载,经过整理] 作者:Chris Anley[chris@ngssoftware.com] An NGSSoftware Insi ...

  9. 如何录制gif动态图片并在CSDN中插入动态图片

    我们在网上浏览别人的博客时,经常可以看到以gif动态图显示的程序效果演示和代码段,那么如何录制gif动态图片并在CSDN中插入动态图片呢?        下面介绍一种简单的方法,了解之后,你也可以将其 ...

  10. pythonfor循环语句例子_Python中的for循环语句

    for循环 for..in是另外一个循环语句,它在一序列的对象上 递归 即逐一使用队列中的每个项目. 使用for语句 案例: fori inrange(1,5):print(i)else:print( ...

最新文章

  1. 油品调和计算软件_燕山石化汽油在线调和系统完成升级改造
  2. 初学Python常见异常错误,总有一处你会遇到!
  3. [导入]决定进入J2EE一探究竟
  4. html网页语言是什么,HTML是什么?
  5. 113. 路径总和 (剑指 Offer 34. 二叉树中和为某一值的路径)(回溯算法)
  6. 使用V-chart时配置踩过的一些坑
  7. android 中 四舍五入的method */
  8. ecs服务器数据迁移_某国际物流集团的云迁移解决方案
  9. 2022中国供应链物流创新科技报告
  10. python scipy stats_Python Scipy stats.binned_statistic_dd()用法及代码示例
  11. three.js 坐标系、camera位置属性、点、线、面
  12. python配置文件注释_python操作配置文件yaml
  13. 中美线规线径对照表(详细版)
  14. Vue导出excel文件
  15. 运放做跟随器有什么要求
  16. Java的重载和重写区别(面试常见)
  17. 论文阅读《“The Boating Store Had Its Best Sail Ever”: Pronunciation-attentive ....》
  18. 住房公积金约定提取业务问答
  19. 自动驾驶中基于地图的视觉定位方法
  20. PyTorch的生态和模型部署

热门文章

  1. Python学习笔记之 高级变量类型 列表,元组,字典,字符串的相关常用 操作
  2. WinEdt 参考文献格式
  3. Kinect2.0 vs2013的配置
  4. Image Pyramids
  5. VS C#生成dll,C#和unity工程调用
  6. opencv 光流法
  7. Atitit enhance dev effect提升开发效率的十大原理与方法v2 u66.docx Atitit enhance dev effect提升开发效率的十大原理 目录 1. 管理 2
  8. Atitit 分布式文件系统总结 fastdfs nfs smb webdav ftp 目录 1.1. webdav 是个好的方案。。。Server client都有 1 1.2. ftp也方便ja
  9. atitit.groovy 语法特性
  10. Atitit. 构造ast 语法树的总结attilax oao