• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

mysql批量剔除指定前缀的表,批量修改表名的SQL语句2012-02-24 11:20转载自

mysql 搞代码 7年前 (2018-06-03) 137次浏览 已收录 0个评论

mysql批量删除指定前缀的表,批量修改表名的SQL语句2012-02-24 11:20转载自
mysql批量删除指定前缀的表,批量修改表名的SQL语句2012-02-24 11:20转载自 系辞下次最终编辑 houyongxuSelect CONCAT( ‘drop table ‘, table_name, ‘;’ ) 

FROM information_schema.tables  Where table_name LIKE ‘uc_%’;

注意: like ‘uc_%’ 其中 uc_是你需要替换的表前缀.
执行查询,会自动生成出 drop table table_name这样的SQL语句.
然后复制 drop语句 可以执行删除的操作了.

这么一来也可以安全的审核一下语句,避免误操作..

顺便补充一下一个批量修改表名的操作方法

Select CONCAT( ‘ALTER TABLE ‘, table_name, ‘RENAME TO ‘, table_name,’;’ ) 

FROM information_schema.tables  Where table_name LIKE ‘uc_%’;

下面这种代码是今天遇到的,表头前面是 db,但是没有下横线显得很乱,于是批量将”dbtable_name”改成”db_table_name”
主要用的函数是mysql的substring函数

mysql教程 substring 字符截取函数
substring(str,pos)语法

substring(filed,m):截取filed字段从第m个字符开始到结束的字符串;

substring(filed,m,n):截取filed字段从第m个字符开始的长度为n的字符串;

str,字符

pos,从第几个开始取

Select CONCAT( ‘ALTER TABLE ‘, table_name, ‘RENAME TO db_’, substring(table_name,3),’;’ ) 

FROM information_schema.tables  Where table_name LIKE ‘db%’;

会得到结果

ALTER TABLE uc_aaa RENAME TO uc_aaa;

ALTER TABLE uc_bbb RENAME TO uc_bbb;

批量复制一下到记事本或者 et之类的编辑工具中,然后批量替换 RENAME TO uc 成 RENAME TO 你想要的表前缀
完成后 再执行.

这样就完成了表名的批量修改拉…

转自:http://www.islandcn.com/post/855.html


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql批量剔除指定前缀的表,批量修改表名的SQL语句2012-02-24 11:20转载自

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址