PHP5.3+连接SQL Server

  • 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文件,将其解压,解压后会新增以下文件
Markdown

  1. 其中54、55、56表示php的5.4.x、5.5.x 和5.6.x版本;
  2. vc6或vc9的选择要看你使用的web服务器软件,如果使用的是IIS那就选择vc9,如果是Apache 则选择vc6;
  3. ts和nts的选择要看你安装的php版本是线程安全版的还是非线程安全版,ts是线程安全,nts是非线程安全。

选择你对应的扩展拷贝到拷到php/ext目录下,在php.ini文件,添加以下代码:

extension=php_pdo_sqlsrv_56_ts.dll(用于pdo)
extension=php_sqlsrv_56_ts.dll

验证连接

  1. 重启服务器,打开phpinfo();看到Registered PHP Streams一栏出现sqlsrv就证明添加扩展成功
  2. 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);
?>
  1. yii2连接方式
$db = new Connection([  
    'dsn' => 'sqlsrv:Server=youripaddress;Database=xxx',  
    'username' => 'yourusername',  
    'password' => 'yourpassword',  
    'charset' => 'utf8',  
]);  
  1. 常用函数
    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
- ODBC Driver 11 下载地址
- ODBC Driver 13 下载地址

具体安装版本可参见下载页面说明,安装后重启即可。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值