首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
phpEnv怎么配置PHP连接SQL Server phpEnv安装pdo_sqlsrv扩展

phpEnv怎么配置PHP连接SQL Server phpEnv安装pdo_sqlsrv扩展

热心网友
46
转载
2026-04-29

phpEnv怎么配置PHP连接SQL Server phpEnv安装pdo_sqlsrv扩展

phpEnv怎么配置PHP连接SQL Server phpEnv安装pdo_sqlsrv扩展

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

一个关键事实是:phpEnv 本身并不内置 pdo_sqlsrv 扩展。这意味着,如果你不手动下载匹配的 DLL 文件并进行配置,那么尝试执行 new PDO("sqlsrv:...") 时,等待你的大概率会是“Class 'PDO' not found”或“Driver not found”这类令人沮丧的错误。

确认 phpEnv 的 PHP 版本和线程安全(TS/NTS)类型

配置的第一步,也是最容易踩坑的地方,就是版本匹配。pdo_sqlsrv 扩展对 PHP 版本、编译器(VC15/VC17)以及线程模型(TS/NTS)这三者有着近乎苛刻的匹配要求。虽然 phpEnv 在 PHP 8.0+ 版本上默认使用 VC17 编译和非线程安全(NTS)模式,但经验告诉我们,最好还是亲自验证一下:

  • 打开命令行,运行 php -v,确认你的 PHP 版本(例如 8.2.12)。
  • 接着,运行 php -i | findstr "Thread Safety"(Windows)或 php -i | grep "Thread Safety"(Linux/macOS)。如果输出显示 enabled,那就是线程安全(TS)版本;如果是 disabled,则是非线程安全(NTS)版本。
  • 最后,运行 php -i | findstr "Compiler" 确认编译器版本,通常是 MSVC17,也可能是 MSVC15

记住,使用一个不匹配的 DLL 文件,后果要么是 Apache 或 Nginx 服务直接启动失败,要么就是扩展加载静默失败,排查起来相当麻烦。

下载并放置正确的 pdo_sqlsrv DLL 文件

确认好环境信息后,下一步就是获取正确的扩展文件。直接前往微软官方的 GitHub 发布页(https://github.com/microsoft/msphpsql/releases),根据你的 PHP 版本和线程类型下载对应的 pdo_sqlsrv*.dll 文件。

立即学习“PHP免费学习笔记(深入)”;

  • 举个例子,如果你的环境是 PHP 8.2、NTS、VC17,那么应该寻找类似 php_pdo_sqlsrv_82_nts.dll 这样的文件。这里有个小细节需要注意:早期版本的文件名中 ts 可能指代线程安全,而 nts 指代非线程安全,但新版本的命名已经统一规范了,务必以实际下载的文件名为准。
  • 下载解压后,将这个 DLL 文件放到 phpEnv 的 ext 目录下。完整路径通常类似于:C:\phpEnv\php\php-8.2.12\ext\php_pdo_sqlsrv_82_nts.dll
  • 还有一点千万别漏了:同目录下通常还需要存在一个 sqlsrv*.dll 文件,因为 pdo_sqlsrv 扩展在内部会依赖它,记得一并放入。

修改 phpEnv 的 php.ini 启用扩展

文件放好了,接下来就是告诉 PHP 去加载它。打开 phpEnv 对应 PHP 版本的 php.ini 配置文件(路径通常是 C:\phpEnv\php\php-8.2.12\php.ini)。

  • 在文件中找到类似 ;extension=php_pdo_sqlsrv 这样的行(前面有分号表示注释)。去掉行首的分号,并将文件名补全为刚才放入的完整名称,例如:extension=php_pdo_sqlsrv_82_nts.dll
  • 同时,确保 extension=php_pdo.dll 这一行已经启用(没有被注释掉),因为 pdo_sqlsrv 是建立在 PDO 核心之上的。
  • 保存修改后,重启 phpEnv 的 Web 服务(Apache 或 Nginx)以及 PHP-FPM(如果使用了的话)。
  • 最后,在命令行中执行 php -m | findstr pdo_sqlsrv,如果能看到输出,恭喜你,扩展已经成功加载了。

连接时 server 参数别写成 127.0.0.1

扩展加载成功,只是万&里长征走完了第一步。在编写连接字符串时,另一个高频错误点在于 server 参数的写法。即使你的 SQL Server 就在本机运行,直接使用 127.0.0.1 也极有可能触发“命名管道提供程序: 无法打开与 SQL Server 的连接”的错误。这其实是 Windows 环境下 TCP/IP 和命名管道协议协商失败的典型表现。

  • 最稳妥的做法是,在 DSN 中优先使用 server=localhost。这样连接会尝试使用共享内存或命名管道,通常比纯 TCP/IP 更稳定。
  • 如果因为某些原因必须使用 IP 地址,请务必显式指定端口号,格式为:server=127.0.0.1,1433。注意,逗号是必须的,并且中间不能有空格。
  • 此外,还需要确保在 SQL Server 配置管理器中已经启用了 TCP/IP 协议,并且在 IPAll 设置中,TCP端口 明确设置为 1433,同时将 TCP动态端口 一项清空。
  • 最后,别忘了检查 Windows 防火墙(尤其是 Windows Defender 防火墙)是否放行了 1433 端口。

说到底,连接 SQL Server 失败,90%以上的问题都出在这三个环节:扩展没正确加载、server 参数写错了、或者 SQL Server 自身的网络协议没配置好。至于其他诸如 LoginTimeout、MultipleActiveResultSets 等连接选项,那都是后话了。

来源:https://www.php.cn/faq/2391020.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

如何在多服务器之间同步phpMyAdmin偏好设置_用户表集中存储
数据库
如何在多服务器之间同步phpMyAdmin偏好设置_用户表集中存储

phpMyAdmin 用户偏好默认存于 MySQL 的 pma__userconfig 表中,需启用高级功能并统一指向中心数据库;跨服务器同步必须共用该表及 controluser,且登录方式不能为 config 模式。 phpMyAdmin 用户偏好存在哪? 很多朋友可能没留意,你每次在 phpM

热心网友
04.29
怎样实现PHP中高安全的SQL防注入方案_结合PDO驱动与参数绑定
数据库
怎样实现PHP中高安全的SQL防注入方案_结合PDO驱动与参数绑定

PDO预处理不能防住所有SQL注入,因默认模拟预处理会拼接参数,且参数绑定仅适用于值,不适用于表名、列名、ORDER BY等结构化部分,须白名单校验。 为什么PDO预处理不能直接防住所有SQL注入 不少开发者有个常见的误解,以为只要代码里用上了 PDO::prepare(),SQL注入的风险就彻底解

热心网友
04.29
ThinkPHP如何在Nginx配置Lua脚本_Nginx扩展ThinkPHP功能逻辑【指南】
编程语言
ThinkPHP如何在Nginx配置Lua脚本_Nginx扩展ThinkPHP功能逻辑【指南】

一、编译安装支持Lua的Nginx 想让Nginx直接跑Lua脚本?原生版本可没这本事。你得先给它“装上轮子”——要么直接用打包好的OpenResty,要么手动给Nginx编译集成lua-nginx-module。这一步是基础,没它,后面和ThinkPHP的配合就无从谈起。 1、先去官网把OpenR

热心网友
04.29
ThinkPHP如何确保环境配置的安全性_敏感信息加密与隐藏
编程语言
ThinkPHP如何确保环境配置的安全性_敏感信息加密与隐藏

ThinkPHP 环境配置安全:别让 env 文件成为你的“后门” ThinkPHP 的 env 文件为什么不能直接放敏感信息 原因其实很直接:在默认的Web服务器配置下, env 文件会被当作一个普通的静态文件来处理。如果部署时路径配置稍有疏忽,攻击者就能直接通过浏览器访问,比如输入 http

热心网友
04.29
ThinkPHP各版本对命令行任务调度的实现差异_定时任务优化
编程语言
ThinkPHP各版本对命令行任务调度的实现差异_定时任务优化

ThinkPHP 5 1 的 `think schedule:run` 为什么总不执行任务? 很多开发者遇到这个问题,第一反应是命令写错了。其实不然,真正的“坑”往往在于一个默认配置的缺失:调度监听器没有被启用。ThinkPHP 5 1 的定时任务机制,其核心是依赖一个名为 think schedu

热心网友
04.29

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

小米note3铃声在哪找?
电脑教程
小米note3铃声在哪找?

小米Note 3铃声管理全攻略:从定位到自定义,一步到位 手里拿着小米Note 3,想换个铃声却找不到地方?别急,这事儿其实比想象中简单。系统预置的铃声,都规规矩矩地躺在内部存储的一个特定文件夹里:SDcard MIUI ringtone 。这个目录就像MIUI系统的“声音仓库”,里面分门别类地存放

热心网友
04.29
小米电饭煲重置网络提示失败怎么回事?
电脑教程
小米电饭煲重置网络提示失败怎么回事?

小米电饭煲重置网络提示失败怎么回事? 遇到小米电饭煲重置网络总是失败,先别急着怀疑是硬件坏了。这事儿本质上,是设备在配网流程中没能和路由器成功“握手”,建立通信授权。背后的原因,往往出在几个容易被忽略的细节上:比如Wi-Fi频段没选对、密码格式太复杂、App里还残留着旧配置,或者是路由器那边设置了“

热心网友
04.29
按摩椅力度调小后还有效果吗
电脑教程
按摩椅力度调小后还有效果吗

按摩椅力度调小后依然有效,关键在于匹配个体身体状态与使用需求 现代中高端按摩椅普遍配备多级力度调节系统,但很多人心里犯嘀咕:力度调小了,是不是就变成隔靴搔痒,没什么实际作用了? 事实恰恰相反。实测数据显示,轻柔档位(比如30%—50%的输出强度)在缓解日常肩颈僵硬、改善浅层血液循环方面,有着明确的生

热心网友
04.29
米家扫地机器人怎么用手机远程控制
电脑教程
米家扫地机器人怎么用手机远程控制

米家扫地机器人怎么用手机远程控制 想随时随地指挥家里的扫地机器人干活?这事儿其实很简单。米家APP就是你的万能遥控器,只要几步设置,无论你是在公司、在出差,还是躺在沙发上,都能稳定、便捷地通过手机远程掌控全局。操作逻辑很清晰:在手机上安装好官方米家APP并登录你的小米账号,让扫地机器人连上家里的Wi

热心网友
04.29
poe交换机测试好坏能用普通测线仪吗
电脑教程
poe交换机测试好坏能用普通测线仪吗

PoE交换机好坏,普通测线仪说了不算 想用普通网线测线仪来判断一台PoE交换机的好坏?这个想法很危险。原因很简单:普通测线仪只能干些基础活儿,比如看看网线通不通、线序对不对、有没有短路断路。但对于PoE交换机的核心能力——供电电压是否达标、输出功率稳不稳定、是否兼容最新的IEEE标准、带载后电压会不

热心网友
04.29