




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、總體上來說,建立mysql數(shù)據(jù)庫時要選定好編碼模式utf-8 utf8-bin 然后就能實現(xiàn)中文錄入。在字符界面和gui界面的顯示差別。在字符中是中文,而在gui界面是亂碼(在字符中是亂碼,而在gui界面是中文)。括號里的情況的解決辦法是。進(jìn)入字符界面時,錄入這句即可mysql.exe -user=root -password=root -default-character-set=gbk 1.例如將所有的編碼都設(shè)置成utf8,jsp的contentType= "text/html;charset=utf-8 " 修改數(shù)據(jù)庫默認(rèn)編碼ALTER DATABASE test D
2、EFAULT CHARACTER SET utf8 COLLATE utf8_bin 修改表的編碼:ALTER TABLE category DEFAULT CHARACTER SET utf8 COLLATE utf8_bin 修改表字段的編碼ALTER TABLE test CHANGE dd dd VARCHAR( 45 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL2. 使用mysql命令進(jìn)入控制臺,默認(rèn)情況下是無法輸入中文,并且也無法正常顯示數(shù)據(jù)庫中已經(jīng)有的中文的.解決辦法是:在進(jìn)入mysql控制臺時,加上參數(shù).示例如下:mysql.ex
3、e -user=root -password=root -default-character-set=gbk如果密碼為空,則示例如下:mysql.exe -user=root -password= -default-character-set=gbk如果你的數(shù)據(jù)庫編碼不是GBK,你也可以把default-character-set換成其它的.有6個關(guān)鍵點(diǎn)使用字符clinent connection database results server system可以通過在mysql控制臺下輸入:show variables lilke character_set_%;查看 mysql4.1以后版本
4、都支持多字符集的支持,但是安裝默認(rèn)的字符集竟然是latin1這個瑞典文,所以很多人想安裝discuz等論壇為gbk、utf-8等字符集的論壇就出現(xiàn)了一些問題。最近我在網(wǎng)上找了一些資料,加上自己又專門在一臺linux服務(wù)器上試驗了兩天的經(jīng)歷,基本解決了字符集的問題,現(xiàn)將我的心得寫出來,供廣大網(wǎng)游參考。一、原理篇:mysql服務(wù)器中有六個關(guān)鍵位置使用了字符集的概念,他們是:client 、connection、database、results、server 、system。a、其中client是客戶端使用的字符集,相當(dāng)于網(wǎng)頁中的字符集設(shè)置如下<metahttp-equiv="Con
5、tent-Type"content="text/html; charset=utf-8">。b、其中的connection是連接數(shù)據(jù)庫的字符集設(shè)置類型,如果php沒有指明連接數(shù)據(jù)庫使用的字符集類型就按照服務(wù)器端默認(rèn)的字符集設(shè)置。c、其中database是數(shù)據(jù)庫服務(wù)器中某個庫使用的字符集設(shè)定,如果建庫時沒有指明,將使用服務(wù)器安裝時指定的字符集設(shè)置。d、results是數(shù)據(jù)庫給客戶端返回時使用的字符集設(shè)定,如果沒有指明,使用服務(wù)器默認(rèn)的字符集。e、server是服務(wù)器安裝時指定的默認(rèn)字符集設(shè)定。f、system是數(shù)據(jù)庫系統(tǒng)使用的字符集設(shè)定。system一般默認(rèn)是
6、utf-8字符集,server是最高的字符集設(shè)定,database沒有單獨(dú)設(shè)定就按照server的字符集設(shè)定,其他都是按照server的設(shè)定設(shè)置字符集。還有,數(shù)據(jù)庫內(nèi)的每個表和字段也都有字符集的概念,一般都是根據(jù)上一級結(jié)構(gòu)決定自身的字符集,比如表就根據(jù)database庫的設(shè)定決定自己的字符集,字段根據(jù)表來決定自己的字符集。二、統(tǒng)一字符集的方法:(以utf-8字符集為例,因為他是目前支持文字種類最廣的字符集)1、徹底解決字符集的方法:要徹底解決字符集的方法就是讓mysql在安裝的時候就是用utf-8的字符集設(shè)定,這樣可以使上面的六個關(guān)鍵點(diǎn)的編碼都為utf-8。a、 在windows下安裝mysq
7、l有提示可以選擇字符集,我們選擇utf-8就可以了。觀者注:修改了mysql的字符集為utf-8,結(jié)果還是無法插入中文。解決:原因是中途修改server的字符編碼,但database的字符編碼還是以前的,需要刪除后,重新新建一個database后就可以插入中文。b、在linux下有三種安裝方法,第一種是rpm包安裝,這種因為我沒有使用過所以沒有發(fā)言權(quán)。第二種為可執(zhí)行程序安裝,這種安裝因為已經(jīng)被編譯成了latin1這種瑞典語的字符集,所以無法完全解決字符集問題,這個版本我們后面會講到怎么解決字符集問題。第三種為源碼自行編譯安裝,這種安裝可以在編譯時設(shè)置字符集類型,這部分主要講這種安裝方式。在編譯
8、mysql是我們可以用這樣的指令:./configure -default-character-set=utf8這樣,在編譯的時候,就會把mysql的server項編譯成utf8的編碼,這樣這個mysql下建立的所有數(shù)據(jù)庫都將使用utf8編碼存儲,所有有關(guān)的方面都是utf8編碼。2、局部解決字符集的方法:如果遇到自己的數(shù)據(jù)庫使用的是默認(rèn)安裝的latin1字符集的(很奇怪為什么mysql要使用這么個默認(rèn)字符集)的情況我們可以這樣來解決。a、默認(rèn)請況下我們在mysql命令行使用status指令察看狀態(tài),可以看到如下內(nèi)容:mysql> status-mysql Ver 14.7 Dis
9、trib 4.1.9, for pc-linux-gnu (i686)Connection id: 62Current database:Current user: rootlocalhostSSL: Not in useCurrent pager: stdoutUsing outfile: ''Using delimiter: ;Protocol version: 10Connection: Localhost via UNIX socketServer characterset: latin1Db characterset:latin1Client characterset
10、:latin1Conn. characterset: latin1UNIX socket: /tmp/mysql.sockUptime: 58 min 23 secThreads: 2 Questions: 1067 Slow queries: 0 Opens: 0 Flush tables: 1 Open tables: 75 Queries per second avg: 0.305-還可以用SHOW VARIABLES LIKE 'character_set_%'指令察看內(nèi)容如下:+-+-+| Variable_name | Value |+-+-+| character
11、_set_client | latin1 | character_set_connection | latin1 | character_set_database |latin1| character_set_filesystem | binary | character_set_results | latin1 | character_set_server |latin1| character_set_system | utf8 |character_sets_dir | /usr/local/src/mysql-5.1.11-beta-linux-i686-glibc23/share/my
12、sql/charsets/ |+-+-+8 rows in set (0.00 sec)這就說明,除system是utf8之外的所有內(nèi)容的字符集都為latin1,我們怎么樣才能使用utf字符集呢?有人說可以在f文件的mysqld段中加入default-character-set=utf8這一項就可以解決,但經(jīng)過我的實驗,這一條完全沒有必要,以下是增加了這一項后得顯示結(jié)果。mysql> status;-mysql Ver 14.7 Distrib 4.1.9, for pc-linux-gnu (i686)Connection id: 62Current database:Curr
13、ent user: rootlocalhostSSL: Not in useCurrent pager: stdoutUsing outfile: ''Using delimiter: ;Protocol version: 10Connection: Localhost via UNIX socketServer characterset: latin1Db characterset: utf8Client characterset: utf8Conn. characterset: latin1UNIX socket: /tmp/mysql.sockUptime: 1 hour
14、 6 min 18 secThreads: 2 Questions: 1071 Slow queries: 0 Opens: 0 Flush tables: 1 Open tables: 75 Queries per second avg: 0.269-mysql> SHOW VARIABLES LIKE 'character_set_%'+-+-+| Variable_name | Value |+-+-+| character_set_client | latin1 | character_set_connection | latin1 | character
15、_set_database | utf8 | character_set_filesystem | binary | character_set_results | latin1 | character_set_server | utf8 | character_set_system | utf8 | character_sets_dir | /usr/local/src/mysql-5.1.11-beta-linux-i686-glibc23/share/mysql/charsets/ |+-+-+8 rows in set (0.00 sec)mysql> SHOW VARI
16、ABLES LIKE 'collation_%'+-+-+| Variable_name | Value |+-+-+| collation_connection | latin1_swedish_ci | collation_database | utf8_general_ci | collation_server | utf8_general_ci |+-+-+3 rows in set (0.01 sec)從上面可以看出,使用了配置文件中修改默認(rèn)字符集的方法,并沒有把client、connection、results這三項改成utf8,而且在建數(shù)據(jù)庫的時候我們可以通過這樣
17、的指令實現(xiàn)數(shù)據(jù)庫的字符集設(shè)置:CREATE DATABASE database DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;這樣此數(shù)據(jù)庫內(nèi)的所有表和字段都將為utf8字符集編碼,所以在配置文件中修改的方法也就失去了意義。b、我的解決辦法。我們可以完全無視數(shù)據(jù)庫默認(rèn)的字符集是什么,我們關(guān)心的只有數(shù)據(jù)庫在建立的時候是不是加入了字符集選擇。(1)使用如下指令建立數(shù)據(jù)庫:CREATE DATABASE database DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;(2)客戶端php程序使
18、用如下方法設(shè)定連接所使用的字符集:PHP程序在查詢數(shù)據(jù)庫之前,執(zhí)行mysql_query("set names utf8;");例子:1. <?php2. mysql_connect('localhost','user','password');3. mysql_select_db('my_db');4.5. /請注意,這步很關(guān)鍵,如果沒有這步,所有的數(shù)據(jù)讀寫都會不正確的6. /它的作用是設(shè)置本次數(shù)據(jù)庫聯(lián)接過程中,數(shù)據(jù)傳輸?shù)哪J(rèn)字符集7. mysql_query("set names utf8;
19、");8.9. /必須將gb2312(本地編碼)轉(zhuǎn)換成utf-8,也可以使用iconv()函數(shù)10. mysql_query(mb_convet_encoding("insert into my_table values('測試');","utf-8","gb2312");11. ?>(3)如果你想使用gb2312編碼,那么建議你使用latin1作為數(shù)據(jù)表的默認(rèn)字符集,這樣就能直接用中文在命令行工具中插入數(shù)據(jù),并且可以直接顯示出來.而不要使用gb2312或者gbk等字符集,如果擔(dān)心查詢排序等問題,可以使
20、用binary屬性約束,例如:create table my_table ( name varchar(20) binary not null default '')type=myisam default charset latin1;自此,使用utf8字符集的完整的例子結(jié)束了。三、舊數(shù)據(jù)升級辦法(1)導(dǎo)出數(shù)據(jù)庫:mysqldump -uroot -p123456 -default-character-set=latin1 -set-charset=utf8 -opt olddatabase > newdatabase.sql(2)修改newdatabase.sq
21、l,在文件開頭增加一條sql語句: “SET NAMES utf8;“,保存。(3)mysql -hlocalhost -uroot my_db <newdatabase.sqlLiunx下修改MySQL字符集:1.查找MySQL的cnf文件的位置find / -iname '*.cnf' -print/usr/share/mysql/my-innodb-heavy-4G.cnf/usr/share/mysql/my-f/usr/share/mysql/my-f/usr/share/mysql/my-f/usr/share/mysql/my-f/usr/share/tex
22、mf/web2c/f/usr/share/texmf/web2c/f/usr/share/texmf/web2c/f/usr/share/texmf/tex/xmltex/f/usr/share/texmf/tex/jadetex/f2. 拷貝 f、my-f、my-f、my-innodb-heavy-4G.cnf其中的一個到/etc下,命名為fcp /usr/share/mysql/my-f /etc/f3. 修改fvi /etc/f在client下添加default-character-set=utf8在mysqld下添加default-character-set=utf84.重新啟動MyS
23、QLrootbogon # /etc/rc.d/init.d/mysql restartShutting down MySQL 確定 Starting MySQL. 確定 rootbogon # mysql -u root -pEnter password:Welcome to the MySQL monitor. Commands end with ; or g.Your MySQL connection id is 1Server version: 5.1.22-rc-community-log MySQL Community Edition (GPL)Type 'help;
24、9; or 'h' for help. Type 'c' to clear the buffer.5.查看字符集設(shè)置mysql> show variables like 'collation_%'+-+-+| Variable_name | Value |+-+-+| collation_connection | utf8_general_ci | collation_database | utf8_general_ci | collation_server | utf8_general_ci |+-+-+3 rows in set (0.
25、02 sec)mysql> show variables like 'character_set_%'+-+-+| Variable_name | Value |+-+-+| character_set_client | utf8 | character_set_connection | utf8 | character_set_database | utf8 | character_set_filesystem | binary | character_set_results | utf8 | character_set_server | utf8 | char
26、acter_set_system | utf8 | character_sets_dir | /usr/share/mysql/charsets/ |+-+-+8 rows in set (0.02 sec)mysql>其他的一些設(shè)置方法:修改數(shù)據(jù)庫的字符集mysql>use mydbmysql>alter database mydb character set utf-8;創(chuàng)建數(shù)據(jù)庫指定數(shù)據(jù)庫的字符集mysql>create database mydb character set utf-8;通過配置文件修改:修改/var/lib/my
27、sql/mydb/db.optdefault-character-set=latin1default-collation=latin1_swedish_ci為default-character-set=utf8default-collation=utf8_general_ci重起MySQL:rootbogon # /etc/rc.d/init.d/mysql restart通過MySQL命令行修改:mysql> set character_set_client=utf8;Query OK, 0 rows affected (0.00 sec)mysql> set c
28、haracter_set_connection=utf8;Query OK, 0 rows affected (0.00 sec)mysql> set character_set_database=utf8;Query OK, 0 rows affected (0.00 sec)mysql> set character_set_results=utf8;Query OK, 0 rows affected (0.00 sec)mysql> set character_set_server=utf8;Query OK, 0 rows affected (0
29、.00 sec)mysql> set character_set_system=utf8;Query OK, 0 rows affected (0.01 sec)mysql> set collation_connection=utf8;Query OK, 0 rows affected (0.01 sec)mysql> set collation_database=utf8;Query OK, 0 rows affected (0.01 sec)mysql> set collation_server=utf8;Query OK, 0 ro
30、ws affected (0.01 sec)查看:mysql> show variables like 'character_set_%'+-+-+| Variable_name | Value |+-+-+| character_set_client | utf8 | character_set_connection | utf8 | character_set_database | utf8 | character_set_filesystem | binary | character_set_results | utf8 | character_set_se
31、rver | utf8 | character_set_system | utf8 | character_sets_dir | /usr/share/mysql/charsets/ |+-+-+8 rows in set (0.03 sec)mysql> show variables like 'collation_%'+-+-+| Variable_name | Value |+-+-+| collation_connection | utf8_general_ci | collation_database | utf8_general_ci | collat
32、ion_server | utf8_general_ci |+-+-+3 rows in set (0.04 sec)-【知識性文章轉(zhuǎn)載】MYSQL 字符集問題MySQL的字符集支持(Character Set Support)有兩個方面:字符集(Character set)和排序方式(Collation)。對于字符集的支持細(xì)化到四個層次:服務(wù)器(server),數(shù)據(jù)庫(database),數(shù)據(jù)表(table)和連接(connection)。1.MySQL默認(rèn)字符集MySQL對于字符集的指定可以細(xì)化到一個數(shù)據(jù)庫,一張表,一列,應(yīng)該用什么字符集。但是,傳統(tǒng)的程序在創(chuàng)建數(shù)據(jù)庫和數(shù)據(jù)表時并沒有使用那
33、么復(fù)雜的配置,它們用的是默認(rèn)的配置,那么,默認(rèn)的配置從何而來呢? (1)編譯MySQL 時,指定了一個默認(rèn)的字符集,這個字符集是 latin1;(2)安裝MySQL 時,可以在配置文件 (my.ini) 中指定一個默認(rèn)的的字符集,如果沒指定,這個值繼承自編譯時指定的;(3)啟動mysqld 時,可以在命令行參數(shù)中指定一個默認(rèn)的的字符集,如果沒指定,這個值繼承自配置文件中的配置,此時 character_set_server 被設(shè)定為這個默認(rèn)的字符集;(4)當(dāng)創(chuàng)建一個新的數(shù)據(jù)庫時,除非明確指定,這個數(shù)據(jù)庫的字符集被缺省設(shè)定為character_set_server;(5)當(dāng)選定了一個數(shù)據(jù)庫時,c
34、haracter_set_database 被設(shè)定為這個數(shù)據(jù)庫默認(rèn)的字符集;(6)在這個數(shù)據(jù)庫里創(chuàng)建一張表時,表默認(rèn)的字符集被設(shè)定為 character_set_database,也就是這個數(shù)據(jù)庫默認(rèn)的字符集;(7)當(dāng)在表內(nèi)設(shè)置一欄時,除非明確指定,否則此欄缺省的字符集就是表默認(rèn)的字符集;簡單的總結(jié)一下,如果什么地方都不修改,那么所有的數(shù)據(jù)庫的所有表的所有欄位的都用 latin1 存儲,不過我們?nèi)绻惭b MySQL,一般都會選擇多語言支持,也就是說,安裝程序會自動在配置文件中把 default_character_set 設(shè)置為 UTF-8,這保證了缺省情況下,所有的數(shù)據(jù)庫的所有表的所有欄位的
35、都用 UTF-8 存儲。2.查看默認(rèn)字符集(默認(rèn)情況下,mysql的字符集是latin1(ISO_8859_1)通常,查看系統(tǒng)的字符集和排序方式的設(shè)定可以通過下面的兩條命令:mysql> SHOW VARIABLES LIKE 'character%'+-+-+| Variable_name | Value |+-+-+| character_set_client | latin1 | character_set_connection | latin1 | character_set_database | latin1 | character_set_filesystem | binary |
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 外資企業(yè)注冊合同協(xié)議
- 圖紙會審合同三方協(xié)議
- 土建外包安全合同協(xié)議
- 天貓合作代運(yùn)營合同協(xié)議
- 培訓(xùn)班機(jī)構(gòu)合同協(xié)議
- 土地歸還協(xié)合同協(xié)議
- 墻地磚購銷合同協(xié)議
- 商標(biāo)運(yùn)營代理合同協(xié)議
- 外賣打包袋轉(zhuǎn)讓合同協(xié)議
- 外協(xié)加工合同協(xié)議書范本
- 實驗室生物安全程序文件
- 企業(yè)融資方式介紹課件
- 藥品生產(chǎn)監(jiān)督管理辦法
- 幼兒園幼兒小籃球活動體能測試表
- 福建省普通高中學(xué)生綜合素質(zhì)學(xué)期評價表
- 五年級下冊數(shù)學(xué)課件 -4.1 用數(shù)對確定位置 ︳青島版 (共20張PPT)
- 柏拉圖分析案例
- 二襯帶模注漿施工方案
- 《英語委婉語與忌語》PPT課件.ppt
- 調(diào)查問卷設(shè)計-課件PPT
- 照金參觀學(xué)習(xí)心得
評論
0/150
提交評論