学编程 ❀(๑╯◡╰๑)❀ 就上soxunxi.cn!这里有CMS,CSS,NET,PHP,Linux,HTML,JAVA,MySQL,Python等教程.
当前位置: MySQL > mysql 存储过程当中运用动态sql语句【MySQL教程】,mysql,存储过程,动态sql语句

简朴的存储历程各个关键字的用法:

CREATE DEFINER = CURRENT_USER PROCEDURE `NewProc`(in _xnb varchar(50))
BEGIN
	## 定义变量
	DECLARE _num FLOAT(14,6) DEFAULT 0;
	## @示意全局变量 相当于php $
	## 拼接赋值 INTO 必须要用全局变量不然语句会报错
    ## //CONCAT会把'SELECT SUM('和_xnb和') INTO @tnum FROM btc_user_coin'拼接起来,CONCAT的各个参数中心以","号支解
	SET @strsql = CONCAT('SELECT SUM(',_xnb,') INTO @tnum FROM btc_user_coin');
	## 预处理须要实行的动态SQL,个中stmt是一个变量
	PREPARE stmt FROM @strsql;  
	## 实行SQL语句
	EXECUTE stmt;  
	## 开释掉预处理段
	deallocate prepare stmt;
	## 赋值给定义的变量
	SET _num = @tnum;
	SELECT _num
END;;

mysql 存储历程当中运用动态sql语句

Mysql 5.0 今后,支撑了动态sql语句,我们能够经由过程通报差别的参数取得我们想要的值

这里引见两种在存储历程当中的动态sql

1.set sql = (预处理的sql语句,能够是用concat拼接的语句)

 set @sql = sql

 PREPARE stmt_name FROM @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;      -- 开释prepareEND;

上述是一个简朴的查询用户表的存储历程,当我们挪用此存储历程,能够依据传入差别的参数取得差别的值。

然则:上述存储历程当中,我们必需在拼接sql语句之前把USER_ID,USER_NAME定义好,而且在拼接sql语句以后,我们没法转变USER_ID,USER_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


       set USER_ID = '2'; -- 主动指定参数USER_ID的值
       set USER_NAME = 'lisi';       set @sql = SQL_FOR_SELECT;       PREPARE stmt FROM @sql;       -- 预处理动态sql语句
       EXECUTE stmt ;                -- 实行sql语句
       deallocate prepare stmt;      -- 开释prepareEND;

 我们用call aa('1','zhangsan');来挪用该存储历程,第一次动态实行,我们取得了‘张三’的信息,然后我们在第14,15即将USER_ID,USER_NAME改成lisi,我们愿望取得李四的相干信息,可查出来的效果依旧是张三的信息,申明我们在拼接sql语句后,不能再转变参数了。

为了处理这类题目,下面引见第二中体式格局:

2.set sql = (预处理的sql语句,能够是用concat拼接的语句,参数用 ?替代)

 set @sql = sql

 PREPARE stmt_name FROM @sql;

 set @var_name = xxx;

 EXECUTE stmt_name USING [USING @var_name [, @var_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 = "select * from user where user_id = ? and user_name = ? ";
-- 拼接查询sql语句

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

set @parm1 = USER_ID; -- 通报sql动态参数
set @parm2 = USER_NAME;

EXECUTE stmt USING @parm1 , @parm2; -- 实行sql语句
deallocate prepare stmt; -- 开释prepare

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

set @parm1 = '2'; -- 通报sql动态参数
set @parm2 = 'lisi';

EXECUTE stmt USING @parm1 , @parm2; -- 实行sql语句
deallocate prepare stmt; -- 开释prepare
END;

如许,我们就能够真正的运用差别的参数(固然也能够在存储历程当中经由过程逻辑生成差别的参数)来运用动态sql了。

几个注重:

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

  • 纵然 preparable_stmt 语句中的 ? 所代表的是一个字符串,你也不须要将 ? 用引号包括起来。

  • 假如动态语句顶用到了 in ,一般写法应当如许:select * from table_name t where t.field1 in (1,2,3,4,...);

  • 则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')) 然则并没有剖析出来,在写存储历程in内里的列表用个传入参数代入的时刻,就须要用到以下体式格局:

1.运用find_in_set函数

select * from table_name t where find_in_set(t.field1,'1,2,3,4');

2.还能够比较笨实的要领,就是组装字符串,然后实行

DROP PROCEDURE IF EXISTS photography.Proc_Test;
CREATE PROCEDURE photography.`Proc_Test`(param1 varchar(1000))
BEGIN
set @id = param1;
set @sel = 'select * from access_record t where t.ID in (';
set @sel_2 = ')';
set @sentence = concat(@sel,@id,@sel_2); -- 衔接字符串生成要实行的SQL语句
prepare stmt from @sentence; -- 预编释一下。 “stmt”预编释变量的称号,
execute stmt; -- 实行SQL语句
deallocate prepare stmt; -- 开释资本
END;

以上就是mysql 存储历程当中运用动态sql语句的细致内容,更多请关注ki4网别的相干文章!

「梦想一旦被付诸行动,就会变得神圣,如果觉得我的文章对您有用,请帮助本站成长」

分享到:
赞(0) 打赏

支付宝扫一扫打赏

微信扫一扫打赏

上一篇:

下一篇:

相关推荐

0 条评论关于"mysql 存储过程当中运用动态sql语句【MySQL教程】,mysql,存储过程,动态sql语句"

最新评论

    暂无留言哦~~

博客简介

看古风美女插画Cos小姐姐,素材合集图集打包下载:炫龙网,好看二次元插画应有尽有,唯美小姐姐等你来。

友情链接

他们同样是一群网虫,却不是每天泡在网上游走在淘宝和网游之间、刷着本来就快要透支的信用卡。他们或许没有踏出国门一步,但同学却不局限在一国一校,而是遍及全球!申请交换友链

服务热线:
 

 QQ在线交流

 旺旺在线