日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

设置mysql的字符编码解决中文乱码问题

發(fā)布時間:2025/1/21 数据库 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 设置mysql的字符编码解决中文乱码问题 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

配置說明

mysql5提供了以下幾個設(shè)置字符集的系統(tǒng)變量:

character_set_client 客戶端字符集

character_set_connection 客戶端與服務(wù)器端連接采用的字符集

character_set_results SELECT查詢返回數(shù)據(jù)的字符集

character_set_database 數(shù)據(jù)庫采用的字符集

亂碼問題一般是由于以上幾個變量設(shè)置錯誤照成的,所以只要理解這幾個變量,就可以告別亂碼了。

使用上述變量,要理解這個核心思想:

character_set_client、character_set_connection、character_set_database編碼要一致;

character_set_results則保證與SELECT返回的結(jié)果與當(dāng)前程序的編碼一致。

我們可以在程序中使用 set names來同時設(shè)置character_set_client, character_set_connection, character_set_results這三個系統(tǒng)變量。

例如set names 'utf8'等同于 :

set character_set_client = ‘utf8’

set character_set_connection = ‘utf8’

set character_set_results = ‘utf8’

一般情況下,當(dāng)數(shù)據(jù)庫與數(shù)據(jù)庫表的字符集為utf8,我們再在程序里設(shè)置set names 'utf8’命令,這樣就能保證無亂碼了,但是,這里還要注意character_set_results變量的值,character_set_results的字符值是用來顯示返回給用戶的編碼的。

例如,你的數(shù)據(jù)庫(character_set_database)用的是utf8的字符集,那么你就要保證character_set_client,character_set_connection也是utf8的字符集。而你的程序也許采用的并不是utf8,比如你的程序用的是gbk,那么你若把character_set_results也設(shè)置為utf8的話就會出現(xiàn)亂碼問題。此時你應(yīng)該把character_set_results設(shè)置為gbk。這樣就能保證數(shù)據(jù)庫返回的結(jié)果與你的程序的編碼一致。

全局設(shè)置,重啟失效

設(shè)置全局的數(shù)據(jù)庫字符編碼,即使基于整個MySQL服務(wù)的,當(dāng)重啟MySQL服務(wù)的時候,編碼依然會變?yōu)樵瓉淼淖址幋a

set global character_set_database=gbk;

set global character_ser_server=gbk;

show variables like ‘%char%’;

永久設(shè)置

設(shè)置永久的字符編碼,即需要在配置文件中修改數(shù)據(jù)庫的字符編碼

編輯 /etc/my.cnf,

在里面加入,已經(jīng)有[XXX]的,在里面直接加入即可。

[mysqld]

character-set-server=utf8

[client]

default-character-set=utf8

[mysql]

default-character-set=utf8

然后重啟數(shù)據(jù)庫即可,service mysql restart.

參考鏈接:
https://blog.csdn.net/zhaojunjie_dream/article/details/79979672
https://www.cnblogs.com/xbq8080/p/6572133.html

總結(jié)

以上是生活随笔為你收集整理的设置mysql的字符编码解决中文乱码问题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。