后端php连接SQL Server数据库报错解决方案

在使用低版本php语言(如5.x.x)连接msSQL数据库时,默认使用mssql连接方式,简单实用。

php 复制代码
$conn=mssql_connect('localhost',userid,password);
mssql_select_db(datatable);
$rs = mssql_query("select top 1 from user",$conn);
$row = mssql_fetch_array($rs)

但是当部分程序更新后,可能导致连接失败,此时就要考虑使用其他连接方式,目前跑通的最便捷的方案就是ODBC连接方式,方案如下:

1、在php.ini确保启用:

extension=php_odbc.dll 或者 extension=php_pdo_odbc.dll

2、然后就可以使用了,操作代码语法不同,示例如下:

php 复制代码
$dsn = "odbc:Driver={SQL Server Native Client 10.0};Server=localhost;Database=datatable";
$pdo = new PDO($dsn, userid, password);
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$stmt = $pdo->query("select top 1 * from users");
$row = $stmt->fetch(PDO::FETCH_ASSOC)

3、在同一个连接上执行多查询时,需要释放前一个结果集。如果是嵌套循环,需要外层查询数据全部取出,释放结果集,示例如下:

php 复制代码
$stmt = $pdo->query("select top 3 * from orders order by id desc");
$orders = $stmt->fetchAll(PDO::FETCH_ASSOC);  // 一次性取出所有数据,释放结果集
$stmt = null;  // 主动释放

foreach ($orders as $row) {
    $orderid = $row['orderid'];
    echo "orderid: $orderid <br>";
    
    try {
        // 现在可以安全执行新查询了
        $result = $pdo->query("select * from carts where orderid='$orderid'");
        if ($result) {
            while ($line = $result->fetch(PDO::FETCH_ASSOC)) {
                echo $line['theday'] . "-" . $line['time'] . "<br>";
            }
            $result = null;  // 释放内层结果集
        }
    } catch (PDOException $e) {
        die("failed: " . $e->getMessage());
    }
}
相关推荐
yongche_shi几秒前
ragas官方文档中文版(五十)
开发语言·python·ai·ragas·如何评估和改进 rag 应用
一路向北he5 分钟前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
国强_dev25 分钟前
技术探讨:使用 stunnel 加密转发数据库连接时,如何获取客户端真实 IP?
数据库·网络协议·tcp/ip
@insist12328 分钟前
系统规划与管理师-信息系统规划核心工作要点解析
数据库·软考·系统规划与管理师·软件水平考试·系统规划与管理工程师
超级数据查看器33 分钟前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
数安3000天1 小时前
增量数据如何自动分类分级,避免目录“过期“?
大数据·数据库
AI行业学习1 小时前
Notepad++ 官方下载 + 完整安装 + 全套优化配置(2026最新)
开发语言·人工智能·python·前端框架·html·notepad++
南墙上的石头2 小时前
麒麟 V10 重装人大金仓 V8R6 踩坑实录(含 MySQL 兼容模式)
数据库·mysql
大圣编程2 小时前
Python中continue语句的用法是什么?
开发语言·前端·python
upgrador3 小时前
基础知识:C++ STL构造函数的左闭右开惯例及其实现原理
开发语言·c++