91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

php中mssql擴展SQL查詢中文字段名亂碼怎么辦

發布時間:2021-02-05 10:39:43 來源:億速云 閱讀:221 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關php中mssql擴展SQL查詢中文字段名亂碼怎么辦,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

一、問題:

數據庫是MS SQLServer2000,要把SQLServer2000里的一張表的數據導入MySQL5,其中SQLServer2000表的字段以簡體中文命名(強烈建議不要以中文做為字段名)。其實操作就是對SQLServer查詢記錄,插入到MySQL里。選擇的腳本語言是PHP,PHP打開MSSQL和MySQL擴展,對這兩個數據庫操作都是很容易的問題。
問題就出現在SQLServer中表的字段名是中文,寫好的查詢語句在SQLServe里測試是通過有記錄返回,用PHP的MSSQL擴展查詢就是報錯。
上網查了資料,網上相關的信息不太多,很多網友都認為是PHP的MSSQL擴展不支持SQL語句中有中文。查了一下資料,PHP的MSSQL是支持SQL中有中文的語句。出現報錯問題大多是因為編碼的問題,編碼數據庫和編碼與查詢語句編碼不統一,查詢語句到SQLServer里中文部分就成了亂碼,造成查詢失敗。

二、解決方法:

知道了原因,接下來分析解決,確認是編碼不統一的問題。解決分以下幾步:
1、確認SQLServer 數據庫的編碼,我的數據編碼是GBK。
2、確認當前PHP腳本文件的編碼,我的編碼是UTF-8。
3、轉換SQL查詢語句的的編碼。
補充:有的網友提到要把PHP的腳本文件編碼轉成和數據庫編碼一致,其實這一步大可不必,只要確認你的SQL語句和數據庫的編碼一致就可以,這里建議不必轉換的原因是如果你的PHP腳本文件里包含其它PHP腳本,那也得對所有include或require的腳本文件編碼轉換,不然PHP腳本編碼不統一很容易出錯,若互相關聯的文件很多,這也是一件很麻煩的問題而且把事情復雜化了。

三、方案:

寫一個轉換函數,在把SQL操作前把SQL語句編碼轉換。下面貼出我的范例代碼:

復制代碼 代碼如下:


//編碼轉換函數
function utf8togb($s) {
return iconv('utf-8', 'gbk//IGNORE', $s); // IGNORE 參數是遇到不成轉換的字符時忽略
}
//建議把所有中文字段用英文別名替換,方便下面操作還有編碼轉換等問題
$sql="SELECT [id], [欄目] as typeid, [正題] as title, [作者] as author, convert(text, [正文]) as body FROM [文章表];";
$sql = utf8togb($sql);

關于“php中mssql擴展SQL查詢中文字段名亂碼怎么辦”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南郑县| 基隆市| 合水县| 临邑县| 逊克县| 仪陇县| 抚宁县| 隆尧县| 麦盖提县| 佛学| 甘谷县| 巨野县| 辽宁省| 榆中县| 乐山市| 兴文县| 江门市| 陆河县| 盖州市| 崇信县| 湖州市| 广东省| 遵化市| 葫芦岛市| 河池市| 周至县| 闻喜县| 常山县| 梧州市| 彝良县| 日喀则市| 延寿县| 上饶县| 望江县| 光山县| 桐柏县| 安乡县| 高要市| 嵊州市| 象山县| 西盟|