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

首頁 > 開發 > PHP > 正文

PHP連接MSSQL顯示中文時為亂碼

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

PHP連接MSSQL顯示中文時為亂碼主要是因為編碼問題了,我們只要懂得一對于數據庫與頁面的編碼統一處理就可以解決了,下面一起來看看下文。

因為一直在使用 windows 下的 PHP 開發,用的是 mysql 數據庫,偶爾也會遇到查詢記錄的亂碼,那是因為 php 編碼不支持中文進行導致的,直接將其進行編碼解碼即可解決,所以在 windows 平臺下還是比較容易解決的。

今天在幫一個客戶進行 liunx 下維護 mssql 數據庫的操作,因站點被攻擊的原因,一直無法進行打開站點,折騰了很久,終于連接上mssql了,今天來了嘗試下查詢,么問題!

可是出來的記錄 中文 顯示是?號或者就是一堆黑框框,這是典型的編碼不對,于是查看了下php.ini關于mssql的這一塊配置,發現有一項配置”mssql.charset”這一項,我配置成 “utf8”,成功解決亂碼。

因為我的程序頁面用的是utf8所以配置成這樣,如果是GBK/GB2312 就配置長相應的編碼就應該能解決,當然遇到這樣的問題還是要看相應情況的,這里還是建議如果能修改配置文件盡可能的去修改配置文件,因為這樣才能一勞永逸的解決掉問題。

例子代碼如下:

  1. $serverName = "127.0.0.1,1433"
  2. $connectionInfo = array"UID"=>"sa"
  3. "PWD"=>"123456"
  4. "Database"=>"NopCommerce"
  5. "CharacterSet"=>"UTF-8"); // 這一行是重點 
  6. //開源代碼Vevb.com 
  7. $conn = sqlsrv_connect($serverName$connectionInfo); 

注意事項:

編碼常用的是utf8-general-ci

不只是表要統一,要統一的總共有四處

一是:數據庫類型,其中包括,數據庫,表,字段三處都要統一,可以檢查一下

二是:文件的編碼類型,你若用dw或editplus可以查看頁面編碼,不同需修改

三是:訪問數據庫時的設置既set NAMES utf8;

四是:瀏覽器顯示方式,添加meta屬性<meta charset=utf-8>

不管用GBK,GB2312,這四處必須統一,看你缺少了哪一步

用PHP操作MSSQL比在ASP連接MYSQL要簡單,所以,當需要MSSQL與MYSQL并存時,用PHP連接MSSQL來操作MYSQL與MSSQL并存比較簡單好用.如果是ASP連接MYSQL,需要安裝一個MYSQL驅動,默認windows的ODBC沒有安裝,很遺憾... 

1.在web服務器上至少安裝了mssql的客戶端 

2.打開php.ini把;extension=php_mssql.dll前面的分號去掉 

有必要話:需要制定extension_dir 

3.推薦使用php<=4.0.9<=5.0.3目前我還沒有連接成功過4.010和5.0.3 

4.數據庫的連接分頁可以到phpe.net上獲取到相應的class

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永康市| 梧州市| 久治县| 岚皋县| 湘乡市| 彭水| 新宁县| 房山区| 巧家县| 宣武区| 桃源县| 太和县| 哈尔滨市| 荣成市| 聊城市| 定西市| 泸溪县| 崇信县| 丰宁| 加查县| 册亨县| 遂昌县| 渝北区| 沽源县| 苏尼特右旗| 岳池县| 东乌珠穆沁旗| 杭锦后旗| 佛山市| 龙陵县| 六枝特区| 大化| 台北市| 黄龙县| 汶川县| 阿荣旗| 菏泽市| 天门市| 拉孜县| 凤凰县| 苏州市|