《PHP教程:php連接微軟MSSQL(sql server)完全攻略》要點:
本文介紹了PHP教程:php連接微軟MSSQL(sql server)完全攻略,希望對您有用。如果有疑問,可以聯(lián)系我們。
在研究ezSQL的時候就看到了mssql_connect()等一些php提供的連接MSSQL的函數(shù),本以為php這個開源的風(fēng)靡世界的編程語言對連接微軟的數(shù)據(jù)應(yīng)該是不在話下的,但是到真正執(zhí)行的時候,才發(fā)現(xiàn)困難多多.PHP應(yīng)用
一開始我下載的php版本是5.93的,下載下來添加環(huán)境變量等等搞了半天后,phpinfo()這個函數(shù)終于成功的運行在瀏覽器中了.然后當(dāng)我在滿世界的找php_mssql.dll,才發(fā)現(xiàn)在5.3以及以上版本的php中已經(jīng)不是原生態(tài)的支持mssql了.PHP應(yīng)用
好不容易找到了微軟Microsoft Drivers 3.0 for PHP for SQL Server,心想微軟的東西應(yīng)該做的可以,卻無奈的發(fā)現(xiàn)SQLSRV30.EXE沒有辦法運行:“SQLSRV30.EXE 不是有效的win32程序”.PHP應(yīng)用
在網(wǎng)上搜索了半天,總結(jié)了以下一些可行的辦法,但是在這之前你需要:PHP應(yīng)用
配置MICROSOFT SQL SERVERPHP應(yīng)用
1、下載并安裝sql server.現(xiàn)在這個版本就比較多了從2000 到2008不等,找一個你自己下載吧.PHP應(yīng)用
2、開放tcp/ip連接方式,使得數(shù)據(jù)庫能夠遠(yuǎn)程訪問.SQL Server Configuration Manager -> Network Configuration -> Protocols -> TCP/IP enabledPHP應(yīng)用
3、打開數(shù)據(jù)管理界面,添加用戶和數(shù)據(jù)庫.PHP應(yīng)用
4、安裝php和配置IIS服務(wù).PHP應(yīng)用
5、打開php所在文件夾里面的 php.ini文件,并添加:PHP應(yīng)用
mssql.textlimit = 20971520 mssql.textsize = 20971520
做完了這些之后,你可以按照下面三種方法來連接數(shù)據(jù)庫了:PHP應(yīng)用
使用php自帶的方法連接MSSQL(5.3及以后版本不適用)PHP應(yīng)用
確保php ext擴(kuò)展庫文件夾下有php_mssql.dll,然后在PHP.ini中的配置中,將PHP應(yīng)用
;extension=php_mssql.dllPHP應(yīng)用
前面的“;”去掉.PHP應(yīng)用
然后你可以測試連接了:PHP應(yīng)用
//連接MSSQL $conn=mssql_connect("實例名或者服務(wù)器IP","用戶名","密碼"); //測試連接 if($conn) { echo "連接成功"; }
Microsoft Drivers for SQL Server for PHPPHP應(yīng)用
2008年7月微軟發(fā)布了一個新的為php連接SQL Server的驅(qū)動,它改善了php自帶的連接MSSQL函數(shù)的一些缺點,并且是以php擴(kuò)展插件的形式開發(fā)的,通過它你可以用php輕松的讀寫微軟的數(shù)據(jù)庫了.PHP應(yīng)用
如果你服務(wù)器使用的是IIS的話,那么就一定要從這里去下載:PHP應(yīng)用
http://php.iis.net/PHP應(yīng)用
因為從上述鏈接進(jìn)去其實是微軟整合的網(wǎng)絡(luò)開發(fā)平臺,只提供在線安裝,但是很方便的整合了PDO插件和php,當(dāng)然還有微軟的其它一些開發(fā)功能,但是如果你沒需要,你可以不裝了,那些是在visual studio中的.PHP應(yīng)用
但是如果你用的是 Apache的話,你可以去這里直接下載這個插件了,它其實是一個解壓文件,解壓出來幾個DLL文件,具體操作如下:PHP應(yīng)用
1)下載驅(qū)動包:http://www.microsoft.com/en-us/download/details.aspx?id=20098.PHP應(yīng)用
2)將DLL文件解壓到 PHP extension_dir 目錄,如果出現(xiàn)說SQLSRV30.EXE 不是有效的win32程序,可能是缺少某些庫,可能是vc10,也有可能是沒有用administrator權(quán)限運行.PHP應(yīng)用
extension_dir = “C:\PHP\ext”PHP應(yīng)用
PHP應(yīng)用
3)在php.ini配置文件內(nèi)引用相應(yīng)的動態(tài)鏈接庫文件PHP應(yīng)用
extension=php_sqlsrv_52_ts_vc6.dll
extension=php_pdo_sqlsrv_52_ts_vc6.dll
extension=php_pdo.dllPHP應(yīng)用
其中的52、53表示就是php的5.2.x和5.3.x 版本,選擇跟你php版本相匹配的;
選擇vc6或vc9的主要看你使用的是什么web服務(wù)器軟件,如果使用的是IIS那就選擇vc9的,如果是Apache則選擇vc6的.
至于ts和nts,就要看你安裝的php版本是線程安全版的還是非線程安全版,ts是線程安全,nts是非線程安全.PHP應(yīng)用
4)重啟Apache
5)連接數(shù)據(jù)庫PHP應(yīng)用
測試連接代碼:PHP應(yīng)用
<?php //本地測試的服務(wù)名 "(local)"; //使用sql server身份驗證,參數(shù)使用數(shù)組的形式,一次是用戶名,密碼,數(shù)據(jù)庫名 //如果你使用的是windows身份驗證,那么可以去掉用戶名和密碼 $connectionInfo = array( "UID"=>"root", "PWD"=>"root2010", "Database"=>"master"); $conn = sqlsrv_connect( $serverName, $connectionInfo); if( $conn ) { echo "Connection established.\n"; } else { echo "Connection could not be established.\n"; die( print_r( sqlsrv_errors(), true)); } ?>
在windows下使用FreeTDSPHP應(yīng)用
什么是FreeTDS? FreeTDS其實就是一個開源(或者可以說成自由)的C程序庫,它可以實現(xiàn)在Linux系統(tǒng)下訪問操作微軟的SQL數(shù)據(jù)庫.可以用在Sybase的db-lib或者ct-lib庫,在里面也包含了一個ODBC的庫.允許許多應(yīng)用軟件連接到Sybase或者微軟的SQL服務(wù)器.FreeTDS是以源碼的現(xiàn)實發(fā)布的,正因為是這樣,所以它幾乎可以在任何系統(tǒng)中進(jìn)行編譯安裝.PHP應(yīng)用
如如你的服務(wù)器是Windows系統(tǒng), 那么你應(yīng)該使用 php_dblib.dll.(more information on Using FreeTDS for Unix.)PHP應(yīng)用
通常我們可以在這個網(wǎng)站上找到這些DLL文件- Frank Kromann's site, 但是它基本上很多都已經(jīng)過時了,并且會引發(fā)很多的問題,因此我們推薦windows下使用PHP 5.2.x版本,并且看看下面的建議 :PHP應(yīng)用
1. 按照下面的表格來下載 php_dblib.dll 并且將其保存到 /PHP/ext 文件夾下面. PHP應(yīng)用
PHP version | Thread Safe | FreeTDS version | Download URL |
---|---|---|---|
PHP 5.2.x (vc6) | Yes | 0.82 + 20090302 patches | Download! |
No | 0.82 + 20090302 patches | Download! | |
PHP 5.3.x (vc9) | Yes | 0.82 + 20090904 patches | Download! |
No | 0.82 + 20090904 patches | Download! | |
PHP 5.4.x (vc9) | Yes | 0.82 + 20110906 patches | Download! FTP Download! |
No | 0.82 + 20110906 patches | Download! FTP Download! |
2、 FreeTDS 需要安裝 .NET Framework v1.1 ,你可以到微軟的網(wǎng)站去下載.或者你去Frank's site 下載需要的DLL文件,并保存到你的/PHP根目錄下面.PHP應(yīng)用
3、在php配置文件 /PHP/php.ini 中添加:PHP應(yīng)用
extension=php_dblib.dllPHP應(yīng)用
4、當(dāng)php引擎啟動FreeTDS模塊的時候需要傳遞一些信息,使得FreeTDS能夠連接到它的默認(rèn)的數(shù)據(jù)庫.因此它的需要在freetds.conf中定義數(shù)據(jù)庫連接的基本信息,該文件在其根目錄下,可以按照你的情況來進(jìn)行修改:PHP應(yīng)用
[global]
host = xxx.xxx.xxx.xxx (host name or ip of the MSSQL server)
port = 1433
client charset = UTF-8
tds version = 8.0
text size = 20971520
5、創(chuàng)建config.php文檔來定義數(shù)據(jù)庫連接參數(shù):PHP應(yīng)用
$CFG->dbtype = 'mssql'; // Required $CFG->dbhost = 'localhost'; // assuming MS SQL is on the same server, otherwise use an IP $CFG->dbname = 'moodle'; // or whatever you called the database you created $CFG->dbuser = 'yourusername'; // I usually use the 'sa' account (dbowner perms are enough) $CFG->dbpass = 'yourpassword'; $CFG->dbpersist = false; $CFG->prefix = 'mdl_'; //Prefix, you can change it, but NEVER leave it blank.
6、 重啟你的網(wǎng)站,如果還是沒有連接到你的數(shù)據(jù)庫的話,在 /PHP/php.ini文件中將display_startup_errors改為"On",當(dāng)你解決了這些問題之后再將錯誤報告改為“Off”;
7、測試你的網(wǎng)站,建立test.php文件,代碼如下,訪問http://localhost/test.php進(jìn)行測試PHP應(yīng)用
<?php $link = mssql_connect('localhost', 'db_user', 'db_password'); if(!$link) { echo'Could not connect'; die('Could not connect: ' . mssql_error()); } echo'Successful connection'; mssql_close($link); ?>
好了windows下使用FreeTDS網(wǎng)上的資料一大堆就不再講了,至此,此篇日志結(jié)束.PHP應(yīng)用
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/2577.html