搜索
写经验 领红包
 > 知识

如何快速有效迁移mysql数据库主键及索引文件(mysql怎么迁移数据库)

导语:如何快速有效迁移mysql数据库主键及索引?

概述

由于业务需要,需迁移测试环境上的索引到正式库上。下面简单记录下迁移过程中的脚本。


1、导出所有索引

包括PRIMARY KEY和INDEX

SELECTCONCAT(&39;,TABLE_NAME,&39;,&39;,IF(NON_UNIQUE = 1,CASEUPPER( INDEX_TYPE ) WHEN &39; THEN&39; WHEN &39; THEN&39; ELSE CONCAT( &39;, INDEX_NAME, &39;, INDEX_TYPE ) END,IF( UPPER( INDEX_NAME ) = &39;, CONCAT( &39;, INDEX_TYPE ), CONCAT( &39;, INDEX_NAME, &39;, INDEX_TYPE ) ) ),&39;,GROUP_CONCAT( DISTINCT CONCAT ( &39;, COLUMN_NAME, &39; ) ORDER BY SEQ_IN_INDEX ASC SEPARATOR &39; ),&39; ) AS &39; FROMinformation_schema.STATISTICS WHERETABLE_SCHEMA = &39; GROUP BYTABLE_NAME,INDEX_NAME ORDER BYTABLE_NAME ASC,INDEX_NAME ASC


2、不包括PRIMARY KEY,只包含INDEX

SELECTCONCAT(&39;,TABLE_NAME,&39;,&39;,IF(NON_UNIQUE = 1,CASEUPPER ( INDEX_TYPE ) WHEN &39; THEN&39; WHEN &39; THEN&39; ELSE CONCAT ( &39;, INDEX_NAME, &39;, INDEX_TYPE ) END,IF( UPPER( INDEX_NAME ) = &39;, CONCAT( &39;, INDEX_TYPE ), CONCAT( &39;, INDEX_NAME, &39;, INDEX_TYPE ) ) ),&39;,GROUP_CONCAT( DISTINCT CONCAT ( &39;, COLUMN_NAME, &39; ) ORDER BY SEQ_IN_INDEX ASC SEPARATOR &39; ),&39; ) AS &39; FROMinformation_schema.STATISTICS WHERETABLE_SCHEMA = &39; AND UPPER( INDEX_NAME ) != &39; GROUP BYTABLE_NAME,INDEX_NAME ORDER BYTABLE_NAME ASC,INDEX_NAME ASC

到正式库执行结果语句即可。


觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~

免责声明:本站部份内容由优秀作者和原创用户编辑投稿,本站仅提供存储服务,不拥有所有权,不承担法律责任。若涉嫌侵权/违法的,请与我联系,一经查实立刻删除内容。本文内容由快快网络小葵创作整理编辑!