生成 MySQL 删除索引、创建索引、分析表的 SQL 语句

目录

[1. 生成删除索引 SQL 语句](#1. 生成删除索引 SQL 语句)

[2. 生成创建索引的 SQL 语句](#2. 生成创建索引的 SQL 语句)

[3. 生成分析表的 SQL 语句](#3. 生成分析表的 SQL 语句)


1. 生成删除索引 SQL 语句

复制代码
mysql -uwxy -p12345 -S /data/18253/mysqldata/mysql.sock -e "
select concat('alter table \`',table_schema,'\`.\`',table_name,'\` ',drop_index,';')
  from (
select table_schema, table_name, group_concat(if(index_name='PRIMARY','drop primary key',concat('drop index \`',index_name,'\`'))) drop_index
  from (
select distinct table_schema, table_name, index_name
  from information_schema.statistics
 where table_schema in ('test')
   and (table_schema, table_name, index_name) not in (
select t1.table_schema, t1.table_name, t1.index_name
  from information_schema.statistics t1, information_schema.columns t2
 where t1.table_schema in ('test')
   and t1.table_schema = t2.table_schema and t1.table_name = t2.table_name and t1.column_name = t2.column_name
   and t2.extra='auto_increment')) t
 group by table_schema, table_name) t;" -N > drop_index.sql

2. 生成创建索引的 SQL 语句

复制代码
mysql -uwxy -p12345 -S /data/18253/mysqldata/mysql.sock -e "
select concat('alter table \`',table_schema,'\`.\`',table_name,'\` ',create_index,';')
  from (
select table_schema, table_name, group_concat(if(index_name='PRIMARY',concat('add primary key (',index_columns,')'),concat('add index \`',index_name,'\` (',index_columns,')'))) create_index
  from (
select table_schema, table_name, index_name, group_concat(concat('\`',column_name,'\`') order by seq_in_index) index_columns
  from information_schema.statistics
 where table_schema in ('test')
   and (table_schema, table_name, index_name) not in (
select t1.table_schema, t1.table_name, t1.index_name
  from information_schema.statistics t1, information_schema.columns t2
 where t1.table_schema in ('test')
   and t1.table_schema = t2.table_schema and t1.table_name = t2.table_name and t1.column_name = t2.column_name
   and t2.extra='auto_increment')
 group by table_schema, table_name, index_name) t
 group by table_schema, table_name) t;" -N > create_index.sql

3. 生成分析表的 SQL 语句

复制代码
mysql -uwxy -p12345 -S /data/18253/mysqldata/mysql.sock -e "
select concat('analyze table \`',table_schema,'\`.\`',table_name,'\`;') 
  from information_schema.tables 
 where table_schema in ('test');" -N > analyze_table.sql
相关推荐
冰糖拌面1 小时前
mysql 和 pg ip 白名单
数据库·tcp/ip·mysql·postgresql
jackletter1 小时前
在pgsql中封装一个json函数,让它完全模拟mysql中的json_set
数据库·mysql·json·pgsql·json_set
邓草1 小时前
phpStudy v8.1 离线版一键安装包(小皮面板)
运维·服务器·mysql
2301_767902641 小时前
mysql语言
数据库·mysql·oracle
北极糊的狐2 小时前
MySQL常见报错分析及解决方案总结(42)---ERROR 1142 (42000): SELECT command denied
java·mysql·adb·myeclipse
西柚小萌新2 小时前
【MySQL数据库】--借助AI快速画数据库ER图
数据库·mysql
V1ncent Chen2 小时前
从零学SQL 05 基础查询
数据库·sql·mysql·数据分析
肥猪猪爸3 小时前
数据库 2PC 极简流程图
java·数据库·分布式·mysql·分布式事务·2pc
七月初七773 小时前
使用Python连接MySQL数据库
数据库·python·mysql
悲伤小伞3 小时前
0-MySQL 在 Centos 7环境详细安装过程
linux·服务器·数据库·mysql·centos