本文章来给大家介绍mysql批量删除相同前缀的表和修改表名,各位同学不防进入参考,如果有很多表需要删除,而表中有相同的前缀,我们可能需要如下语句:
- droptablepre_tablename1;
- droptablepre_tablename2;
- droptablepre_tablename3;
- ......
如果我们手动写,可能需要很多重复性的工作而且可能还不知道表名称,因此我们可以通过sql语句输出上面的删除表语句,执行sql语句,代码如下:
- SelectCONCAT('droptable',table_name,';')
- FROMinformation_schema.tables
- Wheretable_nameLIKE'pre_%';
注意:like ‘pre_%’ 其中 pre_是你需要替换的表前缀,当然你也可以根据自己的情况写规则.
执行查询,会自动把匹配的表生成出 drop table table_name这样的SQL语句,批量复制一下到记事本或者 et之类的编辑工具中,确定你的sql语句是否正确,这么一来也可以安全的审核一下语句,避免误操作..
当然这只是一种思路,也可以用在其他问题中,如批量修改表名的操作方法,代码如下:
- SelectCONCAT('ALTERTABLE',table_name,'RENAMETO',table_name,';')--phpfensi.com
- FROMinformation_schema.tables
- Wheretable_nameLIKE'uc_%';
执行查询,会得到结果,代码如下:
ALTER TABLE uc_aaa RENAME TO uc_aaa;
ALTER TABLE uc_bbb RENAME TO uc_bbb;
批量复制一下到记事本或者 et之类的编辑工具中,然后批量替换 RENAME TO uc 成 RENAME TO 你想要的表前缀,完成后 再执行.