国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php mssql擴展SQL查詢中文字段名解決方法

2024-05-04 23:13:42
字體:
來源:轉載
供稿:網友
一、問題:

數據庫是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);

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 金塔县| 南岸区| 南充市| 五华县| 泗水县| 互助| 汕尾市| 淳化县| 万州区| 吉首市| 保康县| 政和县| 桂林市| 通化县| 吴堡县| 巴青县| 无极县| 东海县| 西昌市| 外汇| 宁陕县| 屯门区| 宜宾市| 民丰县| 绥德县| 泸溪县| 确山县| 武胜县| 罗山县| 德保县| 灵武市| 泰宁县| 竹溪县| 鄯善县| 共和县| 呼伦贝尔市| 岱山县| 临泉县| 沅江市| 花莲市| 大洼县|