自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

MySQL編碼機(jī)制與亂碼

數(shù)據(jù)庫(kù) MySQL
此文章主要描述的是MySQL編碼機(jī)制,以及對(duì)了解MySQL編碼機(jī)制的必要性做一解說(shuō),以下就是文章的主要內(nèi)容描述,望你會(huì)有所收獲。

以下的文章主要是向大家描述的是MySQL編碼機(jī)制, 我們大家都知道從 MySQL4.1 版本開(kāi)始,其支持很多種編碼,包括 latin1、gbk、utf8、big5 等等,當(dāng)然還有一些我們聞所未聞的,以下就是具體內(nèi)容的描述。

 

在使用 PHP 連接 MySQL 查詢出來(lái)的數(shù)據(jù)有的時(shí)候居然會(huì)是亂碼,關(guān)于亂碼的解決首先我們要了解MySQL編碼機(jī)制。

 

拿 Discuz! 論壇為例,Discuz! 論壇在連接 MySQL 后會(huì)立即執(zhí)行一個(gè)設(shè)定(見(jiàn)include/db_mysql.class.php ):

復(fù)制內(nèi)容到剪貼板Code:

@mysql_query("SET character_set_connection=$dbcharset, character_set_results=$dbcharset, character_set_client=binary", $this->link); 此三處的字符設(shè)定很大程度上會(huì)解決亂碼問(wèn)題,那么這三個(gè)設(shè)定具體有什么作用呢?如果我們了解了MySQL編碼機(jī)制,就可以避免在安裝插件及平時(shí)的操作過(guò)程中產(chǎn)生亂碼,還可以自行對(duì)論壇的數(shù)據(jù)進(jìn)行轉(zhuǎn)碼。

character_set_client 我們可以理解為 SQL 語(yǔ)句的編碼,如果設(shè)置為 binary,MySQL 就當(dāng)二進(jìn)制來(lái)處理,character_set_connection 設(shè)定的值則告訴 MySQL 用來(lái)運(yùn)行 SQL 語(yǔ)句的時(shí)候使用的編碼,也就是說(shuō),程序發(fā)送給 MySQL 的 SQL 語(yǔ)句,會(huì)首先被 MySQL 從 character_set_client 指定的編碼轉(zhuǎn)換到 character_set_connection 指定的編碼,如果 character_set_clien 指定的是 binary ,則 MySQL 就會(huì)把 SQL 語(yǔ)句按照 character_set_connection 指定的編碼解釋執(zhí)行。

當(dāng)執(zhí)行 SQL 語(yǔ)句的過(guò)程中,比如向數(shù)據(jù)庫(kù)中插入取出數(shù)據(jù)的時(shí)候,字段也有編碼設(shè)置,如果字段的編碼設(shè)置和 character_set_connection 指定的不同,則 MySQL 會(huì)把插入的數(shù)據(jù)轉(zhuǎn)換成字段設(shè)定的編碼。

當(dāng) SQL 執(zhí)行完畢向客戶端返回?cái)?shù)據(jù)的時(shí)候,會(huì)把數(shù)據(jù)從字段指定的編碼轉(zhuǎn)換為 character_set_results 指定的編碼,如果 character_set_results=NULL 則不做任何轉(zhuǎn)換動(dòng)作,(注意這里設(shè)置為 NULL 不等于沒(méi)有設(shè)置,沒(méi)有設(shè)置的時(shí)候 MySQL 會(huì)繼承全局設(shè)置)。

了解了MySQL編碼機(jī)制,我們就可以利用這個(gè)機(jī)制進(jìn)行數(shù)據(jù)的轉(zhuǎn)碼以及避免在程序使用過(guò)程中出現(xiàn)亂碼了。

補(bǔ)充:

mysql_query("character_set_client=gbk"); 這句告訴 MySQL 我接下來(lái)要用的 SQL 語(yǔ)句的編碼是 GBK 的

mysql_query("character_set_connection=gbk"); 這句 告訴 MySQL 要把 SQL 語(yǔ)句轉(zhuǎn)換成 GBK 進(jìn)行處理

mysql_query("character_set_results=gbk"); 這句告訴 MYSQL 查詢返回的結(jié)果要統(tǒng)一都轉(zhuǎn)換成 GBK 編碼的
 

【編輯推薦】

  1. 對(duì)MySQL數(shù)據(jù)庫(kù)小技巧概述
  2. MySQL游標(biāo)的使用筆記大全
  3. 對(duì)MySQL 存儲(chǔ)過(guò)程中亂碼的破解
  4. MySQL使用rand 隨機(jī)查詢記錄效率測(cè)試
  5. MySQL備份之根據(jù)表備份概述
責(zé)任編輯:佚名 來(lái)源: cnblogs
相關(guān)推薦

2009-06-10 15:27:08

netbeans 編碼亂碼

2009-02-25 15:39:15

亂碼原理MySQL

2010-05-20 10:00:58

MySQL 中文亂碼

2024-03-04 07:50:04

Python字符編碼網(wǎng)絡(luò)通信

2009-07-01 00:23:40

MySQL字符集亂碼

2010-05-31 10:45:09

MySQL+tomca

2010-06-12 11:19:59

MySQL中文亂碼

2009-11-30 11:01:20

MySQL與PHP產(chǎn)生

2010-02-26 13:34:50

WCF編碼機(jī)制

2011-05-16 10:31:19

mysql亂碼

2022-03-11 09:12:06

MySQLMDL

2010-09-11 11:38:45

編碼器故障保護(hù)機(jī)制PowerSmart

2010-05-12 15:34:26

MySQL編碼設(shè)置

2022-01-26 19:42:05

MySQL亂碼排查

2010-05-25 11:33:27

MySQL亂碼

2010-06-07 09:22:21

MySQL+PHP亂碼

2021-09-06 18:55:57

MySQLCheckpoint機(jī)制

2009-11-30 12:58:04

PHP字符集編碼

2010-05-11 14:37:56

MySQL 備份

2009-11-30 10:09:31

PHP中文亂碼
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)