小弟因工作需要要写一个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; 

解决方案 »

  1.   

    表名和数据库名是不可以作为变量直接写在语句里的,不过准备语句解决了这个问题(我实际运行过,放心,好用):
    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 ;