Windows10本地安装SQLserver数据库连接的过程

本人设备环境:Windows10、phpstudy_pro、Nginx1.15.11、php7.3.4

一、下载并安装 ODBC 驱动

访问微软官方下载页面(微软ODBC驱动下载地址),下载适合以下条件的版本:

  • 选择 Windows 64 位 版本
  • 建议下载 ODBC Driver 17 for SQL Server(与 PHP 7.3 兼容性较好)

安装过程按默认设置即可,完成后重启电脑确保驱动生效。

二、在 PHPStudy 中配置 SQL Server 扩展

  1. 打开 PHPStudy Pro,进入「软件管理」→「PHP」→ 找到你的 PHP 7.3 版本

  2. 下载对应版本的扩展文件:

  • 访问微软官方扩展下载页:php扩展微软下载地址(推荐) 或使用 PRCL下载地址
  • 选择与 PHP 7.3、NTS(非线程安全)、x64 匹配的版本
  • 将下载的php_sqlsrv_73_nts_x64.dllphp_pdo_sqlsrv_73_nts_x64.dll复制到PHPStudy安装目录\Extensions\php\php7.3.4nts\ext文件夹中
  1. 点击「设置」→「配置文件」→ 打开php.ini

  2. 在文件中添加以下扩展配置(根据实际情况选择):

bash 复制代码
; SQL Server扩展
extension=php_pdo_sqlsrv_73_nts_x64.dll
extension=php_sqlsrv_73_nts_x64.dll

注意:确保扩展文件名与你实际下载的版本一致

三、验证配置

  1. 重启 PHPStudy 的 Nginx 服务

  2. 创建一个测试 PHP 文件(如test.php),内容如下:

php 复制代码
<?php
phpinfo();
?>
  1. 访问该文件,搜索sqlsrvpdo_sqlsrv,如果能找到相关配置说明扩展已生效

四、测试连接

使用以下代码测试 SQL Server 连接:

php 复制代码
<?php

$serverName = "localhost,1433"; // 明确指定端口号
$connectionInfo = array(
    "Database" => "你的数据库名",
    "Uid" => "sa", // 或你的用户名
    "PWD" => "你的密码",
    "CharacterSet" => "UTF-8"
);

// 建立连接
$conn = sqlsrv_connect($serverName, $connectionInfo);

if($conn) {
    echo "连接成功!";
} else {
    echo "连接失败!";
    die(print_r(sqlsrv_errors(), true));
}

?>

五、如果仍然有问题,检查

  1. 防火墙是否允许连接 SQL Server 端口(默认 1433)

  2. PHPStudy 的 PHP 版本是否确实是 7.3(32 位 / 64 位要与驱动匹配)

  3. ODBC 驱动版本是否与php版本兼容、php扩展的版本是否与php版本兼容

  4. 检查Windows系统环境变量,确保 ODBC 驱动的安装路径已添加到系统环境变量 PATH 中:

  • 按下 Win + R,输入 sysdm.cpl,打开 "系统属性 → 高级 → 环境变量"。
  • 在 "系统变量" 中找到 PATH,检查是否包含 ODBC 驱动的安装路径(通常为 C:\Program Files\Microsoft ODBC Driver 17 for SQL Server\bin\)。
  • 若未包含,点击 "编辑 → 新建",添加上述路径,然后重启电脑生效。
  1. 检查已安装的 ODBC 驱动:
  • 按下Win + R,输入odbcad32.exe打开 "ODBC 数据源管理器"。
  • 切换到 "驱动程序" 选项卡,查看是否有Microsoft ODBC Driver 17 for SQL Server
  • 若未找到,说明驱动安装失败,建议卸载后重新安装与系统架构匹配的驱动(32 位系统装 x86 版本,64 位系统装 x64 版本)。
  1. 检查 SQL Server 服务状态
  • 按下Win + R,输入services.msc,找到SQL Server (MSSQLSERVER)或你的实例服务(如SQL Server (SQLEXPRESS)),确保其状态为 "正在运行"。
  • 若服务未启动,右键 "启动" 即可。
相关推荐
码哥字节14 分钟前
Redis 8.0~8.4 重要更新,新特性很强!
数据库·redis·缓存
未来龙皇小蓝17 分钟前
【MySQL-索引调优】05:索引相关概念
数据库·mysql·性能优化
码农阿豪25 分钟前
MySQL 动态分区管理:自动化与优化实践
数据库·mysql·自动化
givemeacar26 分钟前
redis 使用
数据库·redis·缓存
qiuyuyiyang28 分钟前
MySQL:drop、delete与truncate区别
数据库·mysql
unsynchronized29 分钟前
OpenClaw 安装指南:Linux 与 Windows 系统详细教程
linux·运维·windows·ai
cga194729 分钟前
MySQL:数据查询-limit
数据库·mysql
阿乐艾官30 分钟前
【HBase列式存储数据库】
android·数据库·hbase
2301_8154829342 分钟前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python
Nturmoils2 小时前
从「亡羊补牢」到「规则先行」:金仓数据库 SQL 防火墙实战解析
数据库·后端