MySQL批量修改資料庫的字元集

來源:互聯網
上載者:User

標籤:

 

#走過,試過的路

UPDATE information_schema.`SCHEMATA` SET  DEFAULT_COLLATION_NAME=‘utf8_general_ci‘  WHERE DEFAULT_COLLATION_NAME<>‘utf8_general_ci‘;

#————嘗試使用update語句來修改,這是走不通的,報以下錯誤 沒有許可權。

#錯誤碼: 1044
#Access denied for user ‘root‘@‘%‘ to database ‘information_schema‘

#經過度娘尋找資料,需要使用alter語句才可以修改DB的字元集

ALTER DATABASE mydb CHARACTER SET utf8;

 

#第一步,找出MySQL執行個體中字元集不是utf8的資料庫

SELECT * FROM information_schema.`SCHEMATA` WHERE DEFAULT_COLLATION_NAME<>‘utf8_general_ci‘;

#第二步,修改字元集 

#如果MySQL執行個體上有多個資料庫需要將字元集改為utf8,我們可以採取的策略,如下:

#2.1 使用 CONCAT函數,相信大家看到以下的語句,應該能知道下一步怎麼做了。

SELECT *,CONCAT(‘ ALTER DATABASE ‘,schema_name,‘ CHARACTER SET utf8;‘)strSql FROM information_schema.`SCHEMATA` WHERE DEFAULT_COLLATION_NAME<>‘utf8_general_ci‘;

#2.2 複製出上一個select的結果,粘貼,最後執行

ALTER DATABASE 3_11_測試資料庫1 CHARACTER SET utf8;ALTER DATABASE 3_3_testddb CHARACTER SET utf8;ALTER DATABASE 410_3_test CHARACTER SET utf8;…………

#第三步,檢查驗證是否修改成功

SELECT * FROM information_schema.`SCHEMATA` WHERE DEFAULT_COLLATION_NAME<>‘utf8_general_ci‘;

#<r>查詢:SELECT * FROM information_schema.`SCHEMATA` WHERE DEFAULT_COLLATION_NAME<>‘utf8_general_ci‘ LIMIT 0, 1000
#返回了 0 行

#結果表明,已經沒有字元集不是utf8的庫了

大功告成!

MySQL批量修改資料庫的字元集

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.