Mysql中表名作为参数的问题
近期由于程序的异常,导致数据库中创建了⼤量的表(约4000个),纠结的是表中的数据还都是有⽤的。
需要合并到⼀个表中,⾸先想到的就是使⽤存储过程来处理,但由于表名都是动态⽣成的,需要解决在存储过程中处理以表名作为参数的问题。
1、⽤set或者declare语句将表名定义为变量,在sql中的表名位置使⽤变量,经验证⾏不通,数据库会把变量名当作表名。
2、要进⾏的操作直接⽤concat拼接出来,然后直接执⾏这个sql。可如何在存储过程中执⾏拼接的sql,经查可使⽤PREPARE 来完成。
下⾯是⽰例代码:
将表test_1~test_100中的数据都插⼊到test表中。
a. 数据插⼊使⽤了insert into ... select ..from ... on duplicate key update xxx=$$; (“⽆则插⼊,有则更新”)。
b. 对表test_x进⾏操作之前,断定了表是否存在。在MySQL中库的相关系统都存放在库information_schema中,与表相关的信息存放 在
表TABLES中。
1BEGIN
2DECLARE total INT DEFAULT100;
3
4WHILE total >0 DO
5            # 先判断表test_x是否存在
mysql中select6SELECT count(TABLE_NAME) INTO@tbCount FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA='test'AND TABLE_NAME=CONCAT('test_',total);  7IF@tbCount>0THEN
8SET@InsertData= CONCAT('insert into test (id,name) select t2.id,t2.name from test_',total,' t2 on duplicate key update name=t2.name');
9PREPARE stmt FROM@InsertData;
10EXECUTE stmt;
11SET@dropTable= CONCAT('DROP TABLE test_',total,';');
12PREPARE stmt1 FROM@dropTable;
13EXECUTE stmt1;
14END IF;
15
16SET total = total-1;
17
18END WHILE;
19
20END;