小弟因工作需要要写一个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;
解决方案 »
- 用MySQL Workbench创建的数据库只会生成frm文件和ibd文件,怎么才能生成myd文件和myi文件?
- 急救小弟,请教一个MYSQL查询写法
- 生成binlog时数据库访问速度极慢
- 有个挺基本的问题 想请教一下
- 如何使用xtrabackup
- mysql连接到navicat error1045
- 在mysql中动态建立表,数据库表如果达到10000个,合理吗?
- Mysql有没有取得当前系统时间的c API啊?在线等待。。。。。。。
- 关于一个企业电子商务的数据同步问题
- 查询一个varchar里面的数字
- 如何用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 ;