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)),确保其状态为 "正在运行"。
  • 若服务未启动,右键 "启动" 即可。
相关推荐
堕2741 小时前
MySQL数据库《基础篇--表的增删改查操作CRUD(3)》
数据库·mysql
Xin_z_1 小时前
数据库连接未释放导致表被锁问题排查与处理
数据库
qq_5470261791 小时前
LangChain 模型(Models)
windows·microsoft·langchain
Flobby5291 小时前
深入理解 MySQL 索引:从 B+ 树到索引下推
数据库·后端·mysql
l1t2 小时前
DeepSeek总结的PostgreSQL 中 DISTINCT 的三种用法
数据库·postgresql
众创岛2 小时前
使用IIS运行php程序,处理put和delete请求出现405错误
开发语言·php
西西学代码2 小时前
Flutter---简单画板应用
服务器·数据库·flutter
一只程序熊2 小时前
uniappx richtext img 图片无法显示
linux·服务器·数据库
塔中妖2 小时前
Windows 安装 Maven 详细教程(含镜像与本地仓库配置)
java·windows·maven