2

PHP 5.4.14 SQL Server 2012/SQL 客户端 2012 Windows 2008 R2

我有一个函数(下面是简化版本),我调用它来运行 SQL 查询。它工作正常:连接到数据库;运行查询并获取有效资源。问题是返回的资源是空的......

function squeal($query) {

    $serverName     = "XXXXXXXX\SQLEXPRESS";
    $uid            = "private";
    $pwd            = "private";
    $connectionInfo = array( "UID"=>$uid, "PWD"=>$pwd, "Database"=>"DBname");

    /* Connect using SQL Server Authentication. */
    $conn = sqlsrv_connect( $serverName, $connectionInfo);
    if( $conn === false ) {
         echo "Unable to connect.</br>";
         die( print_r(sqlsrv_errors(), true));
    }
    /* Run query */
    $result = sqlsrv_query( $conn, $query, array(), array("Scrollable"=>"buffered"));
    if( $result === false ) {
         echo "Error in executing query.</br>";
         die( print_r(sqlsrv_errors(), true));
    }
    /* check resource exists for debug (still fails without these lines) */
    echo("Resource=".intval($result)."</br>");
    echo("Has rows=".sqlsrv_has_rows($result)."</br>");

    return $result;
}

$tsql = "SELECT id FROM mytable";
$fred = squeal($tsql);

echo("Resource=".intval($fred)."</br>");
echo("Has rows=".sqlsrv_has_rows($fred)."</br>");

它提供以下输出...

Resource=8
Has rows=1
Resource=8

Warning: sqlsrv_has_rows(): 8 is not a valid ss_sqlsrv_stmt resource in <path> on line 85
Has rows=

SQL 工作正常并返回有效资源。从函数返回时,它知道它已经传递了资源#8(在这种情况下),但它是空的。我对 MySQL 使用了类似的方法,效果很好。我的整个 Intranet 应用程序依赖于能够调用函数来运行查询并取回资源。

将函数留在 sqlsvr/ODBC 中时资源是否“死亡”?肯定不是。

我花了几天时间在谷歌上搜索答案,但只能让 SQL 服务器在函数之外工作。我会很感激任何建议

干杯

4

1 回答 1

3

我发现这是一个引人入胜的问题,在寻找可能的原因时,我发现这个话题听起来似乎很合理。

简而言之:您$conn在功能范围内打开连接资源。因此,离开该范围时将其销毁是有道理的。源自该连接资源的所有资源都自动不再有效,因此这解释了为什么查询资源在退出范围时也会死亡。如果您以这种方式看待它,它也很有意义 - 派生资源如何在没有其逻辑父资源的情况下继续存在。我们只是被 PHP 宠坏了,它通常不关心这一点,但在 C#/Java 等中,这是合理的行为。

如果这个假设是正确的,最简单的解决方案是放在函数global $conn;的开头,squeal这样它就不会超出范围。根据其余代码,您可以实现更优雅(并且潜在冲突更少)的解决方案,无论如何,实现并不是真正的犹太洁食,它连接在一个函数中,然后期望后续在外部生存。

于 2013-05-15T16:39:13.603 回答