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

首頁 > 開發 > PHP > 正文

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

2024-05-04 21:49:20
字體:
來源:轉載
供稿:網友

一、問題:

數據庫是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語句編碼轉換,下面貼出我的范例代碼:

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 苗栗市| 沁源县| 辉县市| 朝阳市| 柏乡县| 安新县| 内乡县| 突泉县| 治县。| 沧源| 丰城市| 凉山| 涪陵区| 墨竹工卡县| 乐山市| 渝中区| 古田县| 正镶白旗| 曲阳县| 宜兴市| 体育| 巨野县| 泗洪县| 崇州市| 游戏| 双城市| 准格尔旗| 利辛县| 兴安县| 济源市| 济南市| 金湖县| 台东县| 礼泉县| 镇巴县| 将乐县| 新密市| 泸定县| 泾源县| 日土县| 延津县|