Mysql 动态SQL

本文介绍如何在MySQL的储存过程中使用表名作为输入参数,通过PREPARE语法实现动态SQL查询。示例代码展示了如何创建储存过程sp1,接受表名变量,拼接并执行SQL语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  我们知道,在MySQL的储存过程中,一般的输入参数为各种数据类型,如数值型,字符型等。那么,能不能让输入参数等于表名呢?答案是肯定的,那就是使用MySQL提供的PREPARE语法。
  关于PREPARE的具体使用方法,可以参考网址:https://dev.mysql.com/doc/refman/5.6/en/sql-syntax-prepared-statements.html .本文将会给出一个在MySQL的储存过程中使用表名为变量的例子。
  打开Navicat For MySQL,在新建查询中,创建示例的储存过程sp1,代码如下:

DROP PROCEDURE IF EXISTS sp1;
CREATE PROCEDURE sp1(IN temp varchar(30))
BEGIN
    #Routine body goes here...
    SET @sqlStr:=CONCAT("select * from ",temp);
    PREPARE stmt from @sqlStr;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;  
END

  该储存过程使用temp为表名,将查询语句“select * from ” , temp拼接为字符串,赋值给sqlStr变量,再用PREPARE将该字符串转化为MySQL脚本中的Prepared Statements stmt, 然后执行stmt即可获得输出结果。最后通过DEALLOCATE释放该Prepared Statements。

set @sqlStr='select * from table where condition1 = ?';
prepare s1 for @sqlStr;
--如果有多个参数用逗号分隔
execute s1 using @condition1;
--手工释放,或者是 connection 关闭时, server 自动回收
deallocate prepare s1;

 

参考文章:https://blog.youkuaiyun.com/jclian91/article/details/80272864

转载于:https://www.cnblogs.com/java-jun-world2099/articles/10305136.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值