php mssql擴(kuò)展SQL查詢中文字段名解決方法
更新時(shí)間:2012年10月15日 01:16:08 作者:
問題就出現(xiàn)在SQLServer中表的字段名是中文,寫好的查詢語(yǔ)句在SQLServe里測(cè)試是通過有記錄返回,用PHP的MSSQL擴(kuò)展查詢就是報(bào)錯(cuò)
一、問題:
數(shù)據(jù)庫(kù)是MS SQLServer2000,要把SQLServer2000里的一張表的數(shù)據(jù)導(dǎo)入MySQL5,其中SQLServer2000表的字段以簡(jiǎn)體中文命名(強(qiáng)烈建議不要以中文做為字段名)。其實(shí)操作就是對(duì)SQLServer查詢記錄,插入到MySQL里。選擇的腳本語(yǔ)言是PHP,PHP打開MSSQL和MySQL擴(kuò)展,對(duì)這兩個(gè)數(shù)據(jù)庫(kù)操作都是很容易的問題。
問題就出現(xiàn)在SQLServer中表的字段名是中文,寫好的查詢語(yǔ)句在SQLServe里測(cè)試是通過有記錄返回,用PHP的MSSQL擴(kuò)展查詢就是報(bào)錯(cuò)。
上網(wǎng)查了資料,網(wǎng)上相關(guān)的信息不太多,很多網(wǎng)友都認(rèn)為是PHP的MSSQL擴(kuò)展不支持SQL語(yǔ)句中有中文。查了一下資料,PHP的MSSQL是支持SQL中有中文的語(yǔ)句。出現(xiàn)報(bào)錯(cuò)問題大多是因?yàn)榫幋a的問題,編碼數(shù)據(jù)庫(kù)和編碼與查詢語(yǔ)句編碼不統(tǒng)一,查詢語(yǔ)句到SQLServer里中文部分就成了亂碼,造成查詢失敗。
二、解決方法:
知道了原因,接下來分析解決,確認(rèn)是編碼不統(tǒng)一的問題。解決分以下幾步:
1、確認(rèn)SQLServer 數(shù)據(jù)庫(kù)的編碼,我的數(shù)據(jù)編碼是GBK。
2、確認(rèn)當(dāng)前PHP腳本文件的編碼,我的編碼是UTF-8。
3、轉(zhuǎn)換SQL查詢語(yǔ)句的的編碼。
補(bǔ)充:有的網(wǎng)友提到要把PHP的腳本文件編碼轉(zhuǎn)成和數(shù)據(jù)庫(kù)編碼一致,其實(shí)這一步大可不必,只要確認(rèn)你的SQL語(yǔ)句和數(shù)據(jù)庫(kù)的編碼一致就可以,這里建議不必轉(zhuǎn)換的原因是如果你的PHP腳本文件里包含其它PHP腳本,那也得對(duì)所有include或require的腳本文件編碼轉(zhuǎn)換,不然PHP腳本編碼不統(tǒng)一很容易出錯(cuò),若互相關(guān)聯(lián)的文件很多,這也是一件很麻煩的問題而且把事情復(fù)雜化了。
三、方案:
寫一個(gè)轉(zhuǎn)換函數(shù),在把SQL操作前把SQL語(yǔ)句編碼轉(zhuǎn)換。下面貼出我的范例代碼:
//編碼轉(zhuǎn)換函數(shù)
function utf8togb($s) {
return iconv('utf-8', 'gbk//IGNORE', $s); // IGNORE 參數(shù)是遇到不成轉(zhuǎn)換的字符時(shí)忽略
}
//建議把所有中文字段用英文別名替換,方便下面操作還有編碼轉(zhuǎn)換等問題
$sql="SELECT [id], [欄目] as typeid, [正題] as title, [作者] as author, convert(text, [正文]) as body FROM [文章表];";
$sql = utf8togb($sql);
數(shù)據(jù)庫(kù)是MS SQLServer2000,要把SQLServer2000里的一張表的數(shù)據(jù)導(dǎo)入MySQL5,其中SQLServer2000表的字段以簡(jiǎn)體中文命名(強(qiáng)烈建議不要以中文做為字段名)。其實(shí)操作就是對(duì)SQLServer查詢記錄,插入到MySQL里。選擇的腳本語(yǔ)言是PHP,PHP打開MSSQL和MySQL擴(kuò)展,對(duì)這兩個(gè)數(shù)據(jù)庫(kù)操作都是很容易的問題。
問題就出現(xiàn)在SQLServer中表的字段名是中文,寫好的查詢語(yǔ)句在SQLServe里測(cè)試是通過有記錄返回,用PHP的MSSQL擴(kuò)展查詢就是報(bào)錯(cuò)。
上網(wǎng)查了資料,網(wǎng)上相關(guān)的信息不太多,很多網(wǎng)友都認(rèn)為是PHP的MSSQL擴(kuò)展不支持SQL語(yǔ)句中有中文。查了一下資料,PHP的MSSQL是支持SQL中有中文的語(yǔ)句。出現(xiàn)報(bào)錯(cuò)問題大多是因?yàn)榫幋a的問題,編碼數(shù)據(jù)庫(kù)和編碼與查詢語(yǔ)句編碼不統(tǒng)一,查詢語(yǔ)句到SQLServer里中文部分就成了亂碼,造成查詢失敗。
二、解決方法:
知道了原因,接下來分析解決,確認(rèn)是編碼不統(tǒng)一的問題。解決分以下幾步:
1、確認(rèn)SQLServer 數(shù)據(jù)庫(kù)的編碼,我的數(shù)據(jù)編碼是GBK。
2、確認(rèn)當(dāng)前PHP腳本文件的編碼,我的編碼是UTF-8。
3、轉(zhuǎn)換SQL查詢語(yǔ)句的的編碼。
補(bǔ)充:有的網(wǎng)友提到要把PHP的腳本文件編碼轉(zhuǎn)成和數(shù)據(jù)庫(kù)編碼一致,其實(shí)這一步大可不必,只要確認(rèn)你的SQL語(yǔ)句和數(shù)據(jù)庫(kù)的編碼一致就可以,這里建議不必轉(zhuǎn)換的原因是如果你的PHP腳本文件里包含其它PHP腳本,那也得對(duì)所有include或require的腳本文件編碼轉(zhuǎn)換,不然PHP腳本編碼不統(tǒng)一很容易出錯(cuò),若互相關(guān)聯(lián)的文件很多,這也是一件很麻煩的問題而且把事情復(fù)雜化了。
三、方案:
寫一個(gè)轉(zhuǎn)換函數(shù),在把SQL操作前把SQL語(yǔ)句編碼轉(zhuǎn)換。下面貼出我的范例代碼:
復(fù)制代碼 代碼如下:
//編碼轉(zhuǎn)換函數(shù)
function utf8togb($s) {
return iconv('utf-8', 'gbk//IGNORE', $s); // IGNORE 參數(shù)是遇到不成轉(zhuǎn)換的字符時(shí)忽略
}
//建議把所有中文字段用英文別名替換,方便下面操作還有編碼轉(zhuǎn)換等問題
$sql="SELECT [id], [欄目] as typeid, [正題] as title, [作者] as author, convert(text, [正文]) as body FROM [文章表];";
$sql = utf8togb($sql);
您可能感興趣的文章:
- Linux編譯mssql擴(kuò)展使用php連接sqlserver2008的使用步驟
- Linux下安裝PHP MSSQL擴(kuò)展教程
- CentOS 6.3下給PHP添加mssql擴(kuò)展模塊教程
- PHP連接MSSQL方法匯總
- php5.3不能連接mssql數(shù)據(jù)庫(kù)的解決方法
- php使用pdo連接mssql server數(shù)據(jù)庫(kù)實(shí)例
- PHP連接MSSQL2008/2005數(shù)據(jù)庫(kù)(SQLSRV)配置實(shí)例
- php連接mssql數(shù)據(jù)庫(kù)的幾種方法
- php連接mssql的一些相關(guān)經(jīng)驗(yàn)及注意事項(xiàng)
- 關(guān)于php連接mssql:pdo odbc sql server
- php 連接mssql數(shù)據(jù)庫(kù) 初學(xué)php筆記
- php adodb連接mssql解決亂碼問題
- PHP基于mssql擴(kuò)展遠(yuǎn)程連接MSSQL的簡(jiǎn)單實(shí)現(xiàn)方法
相關(guān)文章
PHP設(shè)計(jì)模式之調(diào)解者模式的深入解析
本篇文章是對(duì)PHP設(shè)計(jì)模式中的調(diào)解者模式進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP實(shí)現(xiàn)上傳文件并存進(jìn)數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)上傳文件并存進(jìn)數(shù)據(jù)庫(kù)的方法,涉及php文件上傳所涉及的文件與表單操作及數(shù)據(jù)庫(kù)操作相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-07-07PHP調(diào)用存儲(chǔ)過程返回值不一致問題的解決方法分析
這篇文章主要介紹了PHP調(diào)用存儲(chǔ)過程返回值不一致問題的解決方法,結(jié)合實(shí)例形式分析了存儲(chǔ)過程調(diào)用返回值不一致的原因與解決方法,需要的朋友可以參考下2016-04-04Ajax+PHP實(shí)現(xiàn)的分類列表框功能示例
這篇文章主要介紹了Ajax+PHP實(shí)現(xiàn)的分類列表框功能,涉及php結(jié)合ajax交互查詢數(shù)據(jù)庫(kù)與列表框構(gòu)建相關(guān)操作技巧,需要的朋友可以參考下2019-02-02計(jì)算php頁(yè)面運(yùn)行時(shí)間的函數(shù)介紹
本篇文章是對(duì)計(jì)算php頁(yè)面運(yùn)行時(shí)間的函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07php中刪除數(shù)組的第一個(gè)元素和最后一個(gè)元素的函數(shù)
這篇文章主要介紹了php中刪除數(shù)組的第一個(gè)元素和最后一個(gè)元素的函數(shù),需要的朋友可以參考下2015-03-03PHP錯(cuò)誤Warning:mysql_query()解決方法
這篇文章主要介紹了PHP錯(cuò)誤Warning:mysql_query()的解決方法,希望可以真正解決大家的問題,需要的朋友可以參考下2015-10-10