生成 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
相关推荐
蔡蓝41 分钟前
binlog日志以及MySQL的数据同步
数据库·mysql
炒空心菜菜2 小时前
SparkSQL 连接 MySQL 并添加新数据:实战指南
大数据·开发语言·数据库·后端·mysql·spark
专注于大数据技术栈2 小时前
Mac上安装Mysql的详细步骤及配置
mysql
爱喝酸奶的桃酥2 小时前
MYSQL数据库集群高可用和数据监控平台
java·数据库·mysql
数据库幼崽3 小时前
MySQL 8.0 OCP 1Z0-908 61-70题
数据库·mysql·ocp
进击的CJR3 小时前
MySQL 8.0 OCP 英文题库解析(四)
mysql
神仙别闹3 小时前
基于C#+MySQL实现(WinForm)企业设备使用信息管理系统
开发语言·mysql·c#
528305 小时前
MySQL主从复制
数据库·mysql
@解忧杂货铺7 小时前
MySQL历史版本下载及安装配置教程
数据库·mysql
dgiij7 小时前
excel大表导入数据库
数据库·mysql·node.js·excel