您好,登錄后才能下訂單哦!
這篇文章主要講解了“如何解決thinkphp3查詢mssql數據庫亂碼問題”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何解決thinkphp3查詢mssql數據庫亂碼問題”吧!
thinkphp查詢mssql數據庫出現亂碼的原因是ThinkPHP默認為UTF-8,而msmsql數據庫是簡體中文版,存儲的是GB2312編碼
解決方法:
1:在ThinkPHP\Lib\Core 打開Db.class.php,在其最后面加上
2:在Db.class.php找到function select(),在$result = $this->query($sql);后面加一條 $result=iconv2utf8($result),就OK了
復制代碼 代碼如下:
public function iconv2utf8($Result) {
$Row=array();
$key1=array_keys($Result); //取查詢結果$Result的數組的鍵值
//print_r($key1);
$key2=array_keys($Result[$key1[0]]);
//取查詢結果$Result的第一個數組($key1[0])的鍵值
//print_r($key2);
for($i=0;$i<count($key1);$i++) {
for($j=0;$j<count($key2);$j++) {
//取查詢結果編碼改為UTF-8,并存入$Row,且$Row與$Result鍵與值一致
$Row[$key1[$i]][$key2[$j]]=iconv('gb2312','utf-8',$Result[$key1[$i]][$key2[$j]]);
}
}
retrun $Row;
}
感謝各位的閱讀,以上就是“如何解決thinkphp3查詢mssql數據庫亂碼問題”的內容了,經過本文的學習后,相信大家對如何解決thinkphp3查詢mssql數據庫亂碼問題這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。