MySQL批量删除字段跑路?

表多,废物字段多,字段名字很像

当表里有些字段想要删掉,而且字段名字具有一定相似性,可以考虑批量删除

sql 复制代码
-- 查询所有表,生成 DROP COLUMN 的动态 SQL,批量,小心
SELECT CONCAT('ALTER TABLE `', TABLE_NAME, '` ', 
              GROUP_CONCAT('DROP COLUMN `', COLUMN_NAME, '`' SEPARATOR ', '), ';') AS drop_sql
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_SCHEMA = 'impcsv'
AND COLUMN_NAME like '%XXXX%' 
GROUP BY TABLE_NAME;

--替换字段内容
SELECT CONCAT('ALTER TABLE `', TABLE_NAME, '` ', 
              GROUP_CONCAT('rename to `', replace(TABLE_NAME,'/','_'), '`' SEPARATOR ', '), ';') AS drop_sql
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME like '%XXXX%'
GROUP BY TABLE_NAME;

--重命名表名

SELECT CONCAT('ALTER TABLE `', TABLE_NAME, '` ', 
              GROUP_CONCAT('rename to `', replace(TABLE_NAME,'-','_'), '`' SEPARATOR ', '), ';') AS drop_sql
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_SCHEMA = 'impcsv'
GROUP BY TABLE_NAME;

--修改表

SELECT CONCAT('ALTER TABLE `', TABLE_NAME, '` ', 
              GROUP_CONCAT('modify column`',COLUMN_NAME, '` decimal(10,2)' SEPARATOR ', '), ';') AS drop_sql
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_SCHEMA = 'impcsv'
AND COLUMN_NAME like '%XXXX%' 
GROUP BY TABLE_NAME;

怎么做?代码贴进去找到自己的数据库名字,限定好表名,或者字段名,抛出来一大堆语句,把语句贴出来,放到一个查询里面,一键执行

快乐吗?!

一个个写删掉到手软,疯了吧!

友情提示:删库须谨慎,删前先备份,以上仅供个人参考,不构成任何操作建议,如果删错别来骂我!

相关推荐
拄杖忙学轻声码9 分钟前
mysql脚本查询数据,符合指定条件的排在数据列表最前面,实现方式
mysql
IT策士13 分钟前
Redis 从入门到精通:Python 操作 Redis 进阶
数据库·redis·python
IvorySQL19 分钟前
PostgreSQL 技术日报 (6月8日)|索引预取迭代,AI 安全功能上新
数据库·人工智能·sql·安全·postgresql
阿正的梦工坊27 分钟前
【Rust】05-结构体、枚举与模式匹配
java·数据库·rust
cjp56029 分钟前
006.WEB_API使用本地数据库 SQLite + Dapper 入门教程
数据库·sqlite
新新学长搞科研31 分钟前
【广东省博促会主办】2026年第七届先进材料与智能制造国际学术会议(ICAMIM 2026)
大数据·前端·数据库·人工智能·物联网
睡不醒男孩03082334 分钟前
CLup篇之PostgreSQL管理
数据库·postgresql
瀚高PG实验室34 分钟前
数据库启动报错:42501: 无法打开共享内存段 “/PostgreSQL.******“: 权限不够
数据库·postgresql·瀚高数据库
持敬chijing1 小时前
Web渗透之SQL注入-SQLMAP使用笔记
数据库·sql·安全·web安全·网络安全·网络攻击模型
瀚高PG实验室1 小时前
流复制备库停机维护前检查步骤
数据库·瀚高数据库·highgo