小弟因工作需要要写一个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;
解决方案 »
- 这个SQL如何优化
- 一道sql面试题
- asp+mysql中set names语句?
- 【请求加精】如何在mysql和sql server或oracle间进行数据库的转移 保留表里的数据 请高手做个总结!
- mysql的utf8编码问题
- mysql的中文问题怎么解决???怎么插入的时候连中文都写不进去
- 40分---〉哪位朋友能够提供一些asp+sql或者asp+mysql的程序?
- mysql,select for update解锁后怎么再延时2,3秒左右?
- 请问MySQL如何从服务器A往服务器B数据库中复制数据?
- yii框架里面我在新建活动的时候保存了活动的开始时间和结束时间在数据库中,现在要根据保存的开始、结束时间和当前时间来判断活动的状态。
- 如何用creat执行一次查询,建立多个表,也就是一次执行一堆creat创建多个表
- sql语句应该如何写?
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 ;