方法1:通過(guò)客戶端修改表字段的默認(rèn)字符集
按需設(shè)計(jì)網(wǎng)站可以根據(jù)自己的需求進(jìn)行定制,成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)構(gòu)思過(guò)程中功能建設(shè)理應(yīng)排到主要部位公司成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)的運(yùn)用實(shí)際效果公司網(wǎng)站制作網(wǎng)站建立與制做的實(shí)際意義
打開(kāi)SQLyog客戶端,連接數(shù)據(jù)庫(kù)如下圖所示,點(diǎn)擊connection 按鈕 連接數(shù)據(jù)庫(kù)
我的數(shù)據(jù)庫(kù)名稱為edu,然后我隨意找到數(shù)據(jù)庫(kù)中test2表,右鍵-----》Alter Table
如果安裝數(shù)據(jù)庫(kù)的 時(shí)候 沒(méi)有選擇字符集設(shè)置,那么mysql數(shù)據(jù)庫(kù)默認(rèn)為latin1,在箭頭部分選擇utf8字符集
方法2:用數(shù)據(jù)庫(kù)命令修改字符集
首先查看當(dāng)前數(shù)據(jù)庫(kù)字符集,在命令框中執(zhí)行如下命令:show variables like 'character_set_%';
查看字符集排序設(shè)置,執(zhí)行命令:show variables like 'collation_%';
修改服務(wù)器級(jí)別字符集,執(zhí)行命令:
1,臨時(shí)修改:SET GLOBAL character_set_server=utf8;
修改表級(jí)別,命令如下:ALTER TABLE table_name DEFAULT CHARSET utf8;
修改數(shù)據(jù)庫(kù)級(jí)別,命令如下:use edu(換成你要修改的數(shù)據(jù)庫(kù)名,在這里我的數(shù)據(jù)庫(kù)為edu),,然后執(zhí)行命令:alter database edu character set utf-8;
或者修改mysql的my.ini文件中的字符集鍵值
[mysql]
[mysqld]
重啟mysql
首先,MySQL的字符集問(wèn)題主要是兩個(gè)概念,一個(gè)是Character Sets,一個(gè)是Collations,前者是字符內(nèi)容
及編碼,后者是對(duì)前者進(jìn)行比較操作的一些規(guī)則。這兩個(gè)參數(shù)集可以在數(shù)據(jù)庫(kù)實(shí)例、單個(gè)數(shù)據(jù)庫(kù)、表、列等四個(gè)級(jí)
別指定。
對(duì)于使用者來(lái)說(shuō),一般推薦使用utf8編碼來(lái)存儲(chǔ)數(shù)據(jù)。而要解決亂碼問(wèn)題,不單單是MySQL數(shù)據(jù)的存儲(chǔ)問(wèn)題,還
和用戶的程序文件的編碼方式、用戶程序和MySQL數(shù)據(jù)庫(kù)的連接方式都有關(guān)系。
首先,MySQL有默認(rèn)的字符集,這個(gè)是安裝的時(shí)候確定的,在編譯MySQL的時(shí)候可以通過(guò)DEFAULT_CHARSET=
utf8和DEFAULT_COLLATION=utf8_general_ci這兩個(gè)參數(shù)(MySQL5.5版本,5.1版本用--with-charset=
utf8 --with-collation=utf8_general_ci)來(lái)指定默認(rèn)的字符集為utf8,這也是最一勞永逸的辦法,這樣指定后,
客戶端連接到數(shù)據(jù)庫(kù)的編碼方式也默認(rèn)是utf8了,應(yīng)用程序不需要任何處理。
但是遺憾的是,很多人編譯安裝MySQL的時(shí)候沒(méi)有指定這兩個(gè)參數(shù),大多數(shù)人更是通過(guò)二進(jìn)制程序的方式安裝,那
么這時(shí)候MySQL的默認(rèn)字符集是latin1。而這時(shí)候我們?nèi)匀豢梢灾付∕ySQL的默認(rèn)字符集,通過(guò)my.cnf文件增加
兩個(gè)參數(shù):
1.在[mysqld]下添加
default-character-set=utf8(mysql 5.5 版本添加character-set-server=utf8)
2.在[client]下添加
default-character-set=utf8
這樣我們建數(shù)據(jù)庫(kù)建表的時(shí)候就不用特別指定utf8的字符集了。配置文件里的這種寫(xiě)法解決了數(shù)據(jù)存儲(chǔ)和比較的問(wèn)題
,但是對(duì)客戶端的連接是沒(méi)有作用的,客戶端這時(shí)候一般需要指定utf8方式連接才能避免亂碼。也就是傳說(shuō)總的set
names命令。事實(shí)上,set names utf8命令對(duì)應(yīng)的是服務(wù)器端以下幾個(gè)命令:
SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = xutf8;
但這三個(gè)參數(shù)是不能寫(xiě)在配置文件my.cnf里的。只能通過(guò)set命令來(lái)動(dòng)態(tài)修改。我們需要的是在配置文件里寫(xiě)好一勞
永逸的辦法。那么這時(shí)候,是否有在服務(wù)端解決問(wèn)題的辦法呢,可行的思路是在init_connect里設(shè)置。這個(gè)命令在每
個(gè)普通用戶連接上來(lái)的時(shí)候都會(huì)觸發(fā)執(zhí)行,可以在[mysqld]部分增加以下一行設(shè)置連接字符集:
在[mysqld]下添加:
init_connect = 'SET NAMES utf8'
總結(jié):
1、首選在編譯安裝MySQL的時(shí)候指定兩個(gè)參數(shù)使用utf8編碼。
2、次選在配置文件my.cnf或my.ini設(shè)定兩個(gè)參數(shù),同時(shí)設(shè)置init_connect參數(shù)。
3、第三在配置文件my.cnf或my.ini設(shè)定兩個(gè)參數(shù),同時(shí)客戶端的連接指定set names命令。
4、在配置文件my.cnf里的client和server處加入default-character-set參數(shù)方便管理。
mysql數(shù)據(jù)庫(kù)中sql修改字段類(lèi)型可以按照以下方式:
語(yǔ)法規(guī)則:alter table 表名 modify 字段名 新類(lèi)型
例如,有張表student,有id字段是int型的,改為varchar類(lèi)型
alter table student modify id varchar(20);
執(zhí)行該sql語(yǔ)句即可。
注意:如將varchar類(lèi)型轉(zhuǎn)成int類(lèi)型,原字段必須是數(shù)字,
而且int的最大值是4294967295,原字段的值需要小于等于int的最大值才可以。
在sql中給所有字段值加上mysql_real_escape_string函數(shù)處理,作用就是給特殊字符進(jìn)行轉(zhuǎn)義,具體說(shuō)明網(wǎng)上找
$sql="update?`qqaide_ini`?set?`鍵值`='"?.?mysql_real_escape_string($keynamearr[$i+1])?.?"'?WHERE?`PCHash`='"?.?mysql_real_escape_string($PCHash)?.?"'?and?`小節(jié)`='"?.?mysql_real_escape_string($notename)?.?"'?and?`鍵名`='"?.?mysql_real_escape_string($keynamearr[$i])?.?"'";
1、更改服務(wù)器的編碼方式,在終端輸入以下命令:
mysqld --character-set-server=gbk --collation-server=gbk_chinese_ci;
2、更改某個(gè)數(shù)據(jù)庫(kù)的編碼方式
mysql -u root -p
alter database character set gbk collate gbk_chinese_ci;
3、在創(chuàng)建數(shù)據(jù)庫(kù)時(shí)指定編碼:
mysql -u root -p?
create database db_name character set gbk collate gbk_chinese_ci;
4、更改某個(gè)表的編碼方式
mysql -u root -p db_name
alter table table_name convert to? charachter set gbk collate gbk_chinese_ci;
5、在創(chuàng)建表時(shí)指定編碼方式
mysql -u root -p db_name
create table table_name (....) character set gbk collate gbk_chinese_ci;
6、更改某行的編碼方式
mysql -u root -p db_name
alter table table_name modify column_name varchar(20) character set gbk collate gbk_chinese_ci;
7、在創(chuàng)建列時(shí)指定編碼方式:
/prepre name="code" class="sql"mysql -u root -p db_name
create table table_name (..., col1 varchar(20) character set gbk collate gbk_chinese_ci, ...) character set utf8 collate utf8_general_ci;