軟件測試之編程亂碼問題初步探索[2]

發表于:2009-10-12來源:作者:點擊數: 標簽:軟件測試亂碼探索
軟件測試之編程亂碼問題初步探索[2] 軟件測試工具 關鍵字:sql 那么set names是什么呢? set names實際上就是同時設置了character_set_client,character_set_connection,character_set_results這三個系統變量。 例如set names 'gbk'等同于: set @@character

軟件測試之編程亂碼問題初步探索[2]   軟件測試工具

關鍵字:sql 那么set names是什么呢? set names實際上就是同時設置了character_set_client,character_set_connection,character_set_results這三個系統變量。

  例如set names 'gbk'等同于:

set @@character_set_client = 'gbk'

set @@character_set_connection = 'gbk'

set @@character_set_results = 'gbk'

  很多情況下,這樣設置了之后就能把亂碼問題解決了。但是還是不能完全避免出現亂碼的可能,為什么呢?

  因為character_set_client,character_set_connection這兩個變量僅用與保證與character_set_database編碼的一致,而character_set_results則用與保證SELECT返回的結果與程序的編碼一致。

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

  下面我給出一段用于設置字符集的代碼(其中用到了一個我自己寫的db庫,相信應該不影響閱讀):

<?

//假設我們的程序采用的是utf8的字符集

$program_char = 'utf8';

//先檢查mysql的版本號,如果版本號大于4我們才可以設置這些系統變量(mysql4還沒有這些系統變量)

$version = current($db->fetch_one('SELECT VERSION()'));

if (substr($version, 0, 1) > 4)

{

//取出當前數據庫的字符集

$sql = 'SELECT @@character_set_database';

$char = current($db->fetch_one($sql));

//將客戶端字符集(character_set_client)和

連接字符集(character_set_connection)設置為與數據庫字符集(character_set_database)一致

$db->query('SET @@character_set_client = "' . $char . '"');

$db->query('SET @@character_set_connection = "' . $char . '"');

//將SELECT查詢返回數據的字符集設置為與當前程序的字符集一致

$db->query('SET @@character_set_results = "' . $program_char . '"');

}

?>

 

原文轉自:http://www.anti-gravitydesign.com

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97