最近在導入MySQL數據庫時,遇到了一個問題,即將一個GBK編碼的數據表導入到UTF8編碼的數據庫中時,出現了報錯。嘗試了很多解決方案,最終找到了一個可行的方法。
ERROR 1071 (42000) at line 4: Specified key was too long; max key length is 767 bytes
錯誤信息如上所示。首先需要了解一下這個錯誤的含義。啟用了InnoDB引擎的MySQL數據庫在創建索引時,最大索引長度為767字節,也就是說,如果要創建的索引超過了這個長度,就會報錯。
原本的數據表中有一些字段長度超過了767個字節,導致在導入到UTF8編碼的數據庫時出現了問題。解決這個問題的方法有很多,以下是我使用的方法:
1. 將數據表的字符集改為GB2312 ALTER TABLE `table_name` CONVERT TO CHARACTER SET GB2312; 2. 導出數據表 mysqldump -u 用戶名 -p 數據庫名 表名 >/path/to/file.sql 3. 使用文本編輯器打開導出的SQL文件,將其中的所有字符集標識"CHARSET=gb2312"修改為"CHARSET=utf8" s/CHARSET=gb2312/CHARSET=utf8/g 4. 創建新的UTF8編碼的數據庫 CREATE DATABASE `new_database` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; 5. 導入修改后的SQL文件到新的數據庫中 mysql -u 用戶名 -p 新數據庫名< /path/to/file.sql 6. 將新數據庫中的數據表字符集改為UTF8 ALTER TABLE `table_name` CONVERT TO CHARACTER SET utf8; 7. 修改數據表中字段的最大長度 ALTER TABLE `table_name` CHANGE `column_name` `column_name` VARCHAR(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL; 8. 重建索引 ALTER TABLE `table_name` DROP INDEX `index_name`, ADD INDEX `index_name` (`column_name`);
這個方法最后成功地解決了我的問題。在導入數據表之前,一定要確定好數據庫的字符集和字段的最大長度,否則就會出現類似的報錯。希望這篇文章對大家有所幫助。