- php5.2.x自带php_mssql.dll的扩展连接SQL Server,但这个扩展只能支持SQL Server 2000以下版本。
- php连接方式
mssql_connect('localhost', '用户名', '密码');
- php5.3.x不再支持php_mssql.dll扩展库
PHP5.3+配置SQL Sever
详细配置方式可见 https://github.com/Microsoft/msphpsql
下载Microsoft Drivers for PHP for SQL Server
进入https://www.microsoft.com/en-us/download/details.aspx?id=20098
点击download
本人安装的是php环境是5.6.21,选择SQLSRV32.EXE下载
- Version 4.0 supports PHP 7.0+
- Version 3.2 supports PHP 5.6, 5.5, and 5.4
- Version 3.1 supports PHP 5.5 and 5.4
- Version 3.0 supports PHP 5.4.
配置Microsoft Drivers for PHP for SQL Server
下载的文件是一个自解压的 EXE文件,将其解压,解压后会新增以下文件
- 其中54、55、56表示php的5.4.x、5.5.x 和5.6.x版本;
- vc6或vc9的选择要看你使用的web服务器软件,如果使用的是IIS那就选择vc9,如果是Apache 则选择vc6;
- ts和nts的选择要看你安装的php版本是线程安全版的还是非线程安全版,ts是线程安全,nts是非线程安全。
选择你对应的扩展拷贝到拷到php/ext目录下,在php.ini文件,添加以下代码:
extension=php_pdo_sqlsrv_56_ts.dll(用于pdo)
extension=php_sqlsrv_56_ts.dll
验证连接
- 重启服务器,打开phpinfo();看到Registered PHP Streams一栏出现sqlsrv就证明添加扩展成功
- php连接测试
<?php
$serverName = "(local)";
$connectionInfo = array("UID"=>"sa","PWD"=>"admin","Database"=>"test");
$conn = sqlsrv_connect($serverName, $connectionInfo);
if( $conn ){
echo "Connection established.\n";
}else{
echo "Connection could not be established.\n";
die(var_dump(sqlsrv_errors()));
}
sqlsrv_close($conn);
?>
- yii2连接方式
$db = new Connection([
'dsn' => 'sqlsrv:Server=youripaddress;Database=xxx',
'username' => 'yourusername',
'password' => 'yourpassword',
'charset' => 'utf8',
]);
- 常用函数
sqlsrv_connect
sqlsrv_close
sqlsrv_commit
sqlsrv_errors
sqlsrv_fetch
sqlsrv_fetch_array
sqlsrv_fetch_metadata
sqlsrv_num_rows
sqlsrv_query
sqlsrv_rollback
sqlsrv_rows_affected
具体用法可参见php官网
注意事项
需安装ODBC Driver 11 or Microsoft ODBC Driver 13
具体安装版本可参见下载页面说明,安装后重启即可。