MySQL导出、删除索引Index和约束的方法
发布日期:2021-06-30 12:19:04 浏览次数:2 分类:技术文章

本文共 2995 字,大约阅读时间需要 9 分钟。

1. 导出创建自增字段语句:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
SELECT
CONCAT(
'ALTER TABLE `'
,
TABLE_NAME,
'` '
,
'MODIFY COLUMN `'
,
COLUMN_NAME,
'` '
,
IF(
UPPER
(DATA_TYPE) =
'INT'
,
REPLACE
(
SUBSTRING_INDEX(
UPPER
(COLUMN_TYPE),
')'
,
1
),
'INT'
,
'INTEGER'
),
UPPER
(COLUMN_TYPE)
),
') UNSIGNED NOT NULL AUTO_INCREMENT;'
)
FROM
information_schema.COLUMNS
WHERE
TABLE_SCHEMA =
'source_database_name'
AND
EXTRA =
UPPER
(
'AUTO_INCREMENT'
)
ORDER
BY
TABLE_NAME
ASC

2. 导出所有索引:

    2.1 包括PRIMARY KEY和INDEX:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
SELECT
CONCAT(
'ALTER TABLE `'
,TABLE_NAME,
'` '
,
'ADD '
,
 
IF(NON_UNIQUE = 1,
 
CASE
UPPER
(INDEX_TYPE)
 
WHEN
'FULLTEXT'
THEN
'FULLTEXT INDEX'
 
WHEN
'SPATIAL'
THEN
'SPATIAL INDEX'
 
ELSE
CONCAT(
'INDEX `'
,
  
INDEX_NAME,
  
'` USING '
,
  
INDEX_TYPE
 
)
END
,
IF(
UPPER
(INDEX_NAME) =
'PRIMARY'
,
 
CONCAT(
'PRIMARY KEY USING '
,
 
INDEX_TYPE
 
),
CONCAT(
'UNIQUE INDEX `'
,
 
INDEX_NAME,
 
'` USING '
,
 
INDEX_TYPE
)
)
),
'('
, GROUP_CONCAT(
DISTINCT
CONCAT(
'`'
, COLUMN_NAME,
'`'
)
ORDER
BY
SEQ_IN_INDEX
ASC
SEPARATOR
', '
),
');'
)
AS
'Show_Add_Indexes'
FROM
information_schema.
STATISTICS
WHERE
TABLE_SCHEMA =
'source_database_name'
GROUP
BY
TABLE_NAME, INDEX_NAME
ORDER
BY
TABLE_NAME
ASC
, INDEX_NAME
ASC

  2.2 不包括PRIMARY KEY,只包含INDEX:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
SELECT
CONCAT(
'ALTER TABLE `'
,TABLE_NAME,
'` '
,
'ADD '
,
 
IF(NON_UNIQUE = 1,
 
CASE
UPPER
(INDEX_TYPE)
 
WHEN
'FULLTEXT'
THEN
'FULLTEXT INDEX'
 
WHEN
'SPATIAL'
THEN
'SPATIAL INDEX'
 
ELSE
CONCAT(
'INDEX `'
,
  
INDEX_NAME,
  
'` USING '
,
  
INDEX_TYPE
 
)
END
,
IF(
UPPER
(INDEX_NAME) =
'PRIMARY'
,
 
CONCAT(
'PRIMARY KEY USING '
,
 
INDEX_TYPE
 
),
CONCAT(
'UNIQUE INDEX `'
,
 
INDEX_NAME,
 
'` USING '
,
 
INDEX_TYPE
)
)
),
'('
, GROUP_CONCAT(
DISTINCT
CONCAT(
'`'
, COLUMN_NAME,
'`'
)
ORDER
BY
SEQ_IN_INDEX
ASC
SEPARATOR
', '
),
');'
)
AS
'Show_Add_Indexes'
FROM
information_schema.
STATISTICS
WHERE
TABLE_SCHEMA =
'source_database_name'
AND
UPPER(INDEX_NAME) != 'PRIMARY'
GROUP
BY
TABLE_NAME, INDEX_NAME
ORDER
BY
TABLE_NAME
ASC
, INDEX_NAME
ASC

3. 创建删除所有自增字段:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
SELECT
CONCAT(
'ALTER TABLE `'
,
TABLE_NAME,
'` '
,
'MODIFY COLUMN `'
,
COLUMN_NAME,
'` '
,
IF(
UPPER
(DATA_TYPE) =
'INT'
,
REPLACE
(
SUBSTRING_INDEX(
UPPER
(COLUMN_TYPE),
')'
,
1
),
'INT'
,
'INTEGER'
),
UPPER
(COLUMN_TYPE)
),
') UNSIGNED NOT NULL;'
)
FROM
information_schema.COLUMNS
WHERE
TABLE_SCHEMA =
'destination_database_name'
AND
EXTRA =
UPPER
(
'AUTO_INCREMENT'
)
ORDER
BY
TABLE_NAME
ASC

4. 删除库所有索引:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
SELECT
CONCAT(
'ALTER TABLE `'
,
TABLE_NAME,
'` '
,
GROUP_CONCAT(
DISTINCT
CONCAT(
'DROP '
,
IF(
UPPER
(INDEX_NAME) =
'PRIMARY'
,
'PRIMARY KEY'
,
CONCAT(
'INDEX `'
, INDEX_NAME,
'`'
)
)
)
SEPARATOR
', '
),
';'
)
FROM
information_schema.
STATISTICS
WHERE
TABLE_SCHEMA =
'destination_database_name'
GROUP
BY
TABLE_NAME
ORDER
BY
TABLE_NAME
ASC

转载地址:https://java-basketball.blog.csdn.net/article/details/77801536 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:Nexus Repository Manager 3 installing with Docker
下一篇:Linux 用echo清空文件

发表评论

最新留言

不错!
[***.144.177.141]2024年04月07日 22时27分19秒