軟件測試之編程亂碼問(wèn)題初步探索[2] 軟件測試工具
關(guān)鍵字:sql 那么set names是什么呢? set names實(shí)際上就是同時(shí)設置了character_set_client,character_set_connection,character_set_results這三個(gè)系統變量。
例如set names 'gbk'等同于:
set @@character_set_client = 'gbk'
set @@character_set_connection = 'gbk'
set @@character_set_results = 'gbk'
很多情況下,這樣設置了之后就能把亂碼問(wèn)題解決了。但是還是不能完全避免出現亂碼的可能,為什么呢?
因為character_set_client,character_set_connection這兩個(gè)變量?jì)H用與保證與character_set_database編碼的一致,而character_set_results則用與保證SELECT返回的結果與程序的編碼一致。
例如,你的數據庫(character_set_database)用的是utf8的字符集,那么你就要保證character_set_client,character_set_connection也是utf8的字符集。而你的程序也許采用的并不是utf8,比如你的程序用的是gbk,那么你若把character_set_results也設置為utf8的話(huà)就會(huì )出現亂碼問(wèn)題。此時(shí)你應該把character_set_results設置為gbk。這樣就能保證數據庫返回的結果與你的程序的編碼一致。
下面我給出一段用于設置字符集的代碼(其中用到了一個(gè)我自己寫(xiě)的db庫,相信應該不影響閱讀):
<?
//假設我們的程序采用的是utf8的字符集
$program_char = 'utf8';
//先檢查mysql的版本號,如果版本號大于4我們才可以設置這些系統變量(mysql4還沒(méi)有這些系統變量)
$version = current($db->fetch_one('SELECT VERSION()'));
if (substr($version, 0, 1) > 4)
{
//取出當前數據庫的字符集
$sql = 'SELECT @@character_set_database';
$char = current($db->fetch_one($sql));
//將客戶(hù)端字符集(character_set_client)和
連接字符集(character_set_connection)設置為與數據庫字符集(character_set_database)一致
$db->query('SET @@character_set_client = "' . $char . '"');
$db->query('SET @@character_set_connection = "' . $char . '"');
//將SELECT查詢(xún)返回數據的字符集設置為與當前程序的字符集一致
$db->query('SET @@character_set_results = "' . $program_char . '"');
}
?>
文章來(lái)源于領(lǐng)測軟件測試網(wǎng) http://kjueaiud.com/