【小白专用】php以pdo方式连接sqlserver,开启sqlsrv扩展

一、安装ODBC程序,

下载适用于 SQL Server 的 ODBC 驱动程序 - 适用于 SQL Server 的 ODBC 驱动程序 |Microsoft 学习

运行安装程序,出现如下图所示页面;

选择下一步;选择我同意许可协议中的条款后选择下一步;

点击安装;

点击完成后就成功安装了驱动程序

打开用phpinfo()查看php版本信息。如下

<?php

echo phpinfo();

?>

二、下载,配置sqlsrv扩展文件

1、下载sqlsrv扩展文件,建议下载5.11:

下载 Microsoft SQL Server PHP 驱动程序 - SQL Server PHP 驱动程序 |Microsoft 学习

下载的是一个自解压的文件,解压后会有一堆dll文件

2、把扩展文件对应的版本移动到PHP对应的目录下的ext目录;

php_pdo_sqlsrv_82_ts_x64.dll

php_sqlsrv_82_ts_x64.dll

3、更改PHP的配置文件,添加扩展,(以php8.2.13为例)
extension=php_pdo_sqlsrv_82_ts_x64
extension=php_sqlsrv_82_ts_x64

4、重启服务

总结:开启扩展后,还需要下载 Microsoft ODBC Driver 18 for SQL Server ,即第一步操作

报错:PDOException: could not find driver
原因:未装驱动
调用phpinfo可看是否装了驱动(pdo_drivers enabled 有的就是可用驱动)比如oci就是连接oracle,sqlsrv就是连接sqlserver

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Linux 的 Docker 容器中已有 PHP 环境的情况下,可以通过在容器中安装 MSSQL 驱动程序以及 pdo_sqlsrvsqlsrv 两个扩展连接 SQL Server 数据库。以下是安装步骤: 1. 进入容器 执行以下命令进入容器: ``` docker exec -it container_name /bin/bash ``` 其中 container_name 是容器的名称或 ID。 2. 安装必要的依赖项 在容器中执行以下命令安装必要的依赖项: ``` apt-get update apt-get install -y \ unixodbc-dev \ gnupg2 \ curl ``` 3. 添加 Microsoft 的存储库并安装 MSSQL 驱动程序 在容器中执行以下命令添加 Microsoft 的存储库并安装 MSSQL 驱动程序: ``` curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - curl https://packages.microsoft.com/config/debian/10/prod.list > /etc/apt/sources.list.d/mssql-release.list apt-get update ACCEPT_EULA=Y apt-get install -y \ msodbcsql17 \ mssql-tools \ libgssapi-krb5-2 ``` 4. 安装 pdo_sqlsrvsqlsrv 扩展 在容器中执行以下命令安装 pdo_sqlsrvsqlsrv 扩展: ``` pecl install pdo_sqlsrv sqlsrv docker-php-ext-enable pdo_sqlsrv sqlsrv ``` 5. 重启 Apache 服务 在容器中执行以下命令重启 Apache 服务: ``` apachectl -k restart ``` 6. 测试连接 SQL Server 数据库 在 PHP 代码中使用如下方式连接 SQL Server 数据库: ```php $serverName = "your_server_name"; // SQL Server 服务器名称 $connectionOptions = array( "Database" => "your_database_name", // 数据库名称 "Uid" => "your_username", // 用户名 "PWD" => "your_password" // 密码 ); // 创建连接 $conn = sqlsrv_connect($serverName, $connectionOptions); // 检查连接是否成功 if ($conn === false) { die(print_r(sqlsrv_errors(), true)); } else { echo "Connected successfully."; } // 关闭连接 sqlsrv_close($conn); ``` 如果运行结果输出 Connected successfully.,则表示连接成功。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值