mysql带参数的存储过程 执行多条动态语句的问题
时间:2011-07-29
来源:互联网
             小弟因工作需要要写一个mysql的存储过程,具体需求如下:把一个数据库表的数据写入另一个数据库中的表中。表结构都是相同的。存储过程的参数为数据库名称和表的名称。但是老是报错,论坛的各位大哥,希望指点下小弟,困扰好几天了。
create PROCEDURE proc_test(
IN dbName VARCHAR(50),
IN tableName VARCHAR(50)
)
BEGIN
INSERT INTO tableName select * from dbName.tableName;
delete from dbName.tableName;
END;
            create PROCEDURE proc_test(
IN dbName VARCHAR(50),
IN tableName VARCHAR(50)
)
BEGIN
INSERT INTO tableName select * from dbName.tableName;
delete from dbName.tableName;
END;
作者: santaandsorlon 发布时间: 2011-07-29
             表名和数据库名是不可以作为变量直接写在语句里的,不过准备语句解决了这个问题(我实际运行过,放心,好用):
DELIMITER $$
DROP PROCEDURE IF EXISTS proc_test $$
create PROCEDURE proc_test(
IN dbName VARCHAR(50),
IN tableName VARCHAR(50)
)
BEGIN
SET @sql = CONCAT('INSERT INTO ',tableName,' select * from ',dbName,'.',tableName);
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET @sql= CONCAT('DELETE FROM ',dbName,'.',tableName);
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END $$
DELIMITER ;
            DELIMITER $$
DROP PROCEDURE IF EXISTS proc_test $$
create PROCEDURE proc_test(
IN dbName VARCHAR(50),
IN tableName VARCHAR(50)
)
BEGIN
SET @sql = CONCAT('INSERT INTO ',tableName,' select * from ',dbName,'.',tableName);
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET @sql= CONCAT('DELETE FROM ',dbName,'.',tableName);
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END $$
DELIMITER ;
作者: liuxinran819 发布时间: 2011-07-29
 相关阅读 更多  
      
    热门阅读
-  
 office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
          阅读:74
 -  
 如何安装mysql8.0
          阅读:31
 -  
 Word快速设置标题样式步骤详解
          阅读:28
 -  
 20+道必知必会的Vue面试题(附答案解析)
          阅读:37
 -  
 HTML如何制作表单
          阅读:22
 -  
 百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
          阅读:31
 -  
 ET文件格式和XLS格式文件之间如何转化?
          阅读:24
 -  
 react和vue的区别及优缺点是什么
          阅读:121
 -  
 支付宝人脸识别如何关闭?
          阅读:21
 -  
 腾讯微云怎么修改照片或视频备份路径?
          阅读:28
 















