首页 > 代码库 > Mysql中表名作为参数的问题
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中。
1 BEGIN 2 DECLARE total INT DEFAULT 100; 3 4 WHILE total >0 DO 5 # 先判断表test_x是否存在 6 SELECT count(TABLE_NAME) INTO @tbCount FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA=‘test‘ AND TABLE_NAME=CONCAT(‘test_‘,total); 7 IF @tbCount >0 THEN 8 SET @InsertData = CONCAT(‘insert into test (id,name) select t2.id,t2.name from test_‘,total,‘ t2 on duplicate key update name=t2.name‘); 9 PREPARE stmt FROM @InsertData; 10 EXECUTE stmt; 11 SET @dropTable = CONCAT(‘DROP TABLE test_‘,total,‘;‘);12 PREPARE stmt1 FROM @dropTable; 13 EXECUTE stmt1; 14 END IF;15 16 SET total = total-1;17 18 END WHILE;19 20 END;
Mysql中表名作为参数的问题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。