PHP串連MSSQL顯示中文時為亂碼_PHP教程

來源:互聯網
上載者:User

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


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

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

  今天在幫一個客戶進行 liunx 下維護 mssql 資料庫的操作,因網站被攻擊的原因,一直無法進行開啟網站,折騰了很久,終於串連上mssql了,今天來了嘗試下查詢,麼問題!

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

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

  例子

代碼如下

$serverName = "127.0.0.1,1433";
$connectionInfo = array( "UID"=>"sa",
"PWD"=>"123456",
"Database"=>"NopCommerce",
"CharacterSet"=>"UTF-8"); // 這一行是重點
$conn = sqlsrv_connect($serverName, $connectionInfo);

  注意事項:

  編碼常用的是utf8-general-ci

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

  一是:資料庫類型,其中包括,資料庫,表,欄位三處都要統一,可以檢查一下

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

  三是:訪問資料庫時的設定既set NAMES utf8;

  四是:瀏覽器顯示方式,添加meta屬性

  不管用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

http://www.bkjia.com/PHPjc/869305.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/869305.htmlTechArticlePHP串連MSSQL顯示中文時為亂碼 PHP串連MSSQL顯示中文時為亂碼主要是因為編碼問題了,我們只要懂得一對於資料庫與頁面的編碼統一處理就可...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.