我正在尝试使用 php 在 SQL 服务器中显示行

I'm trying to display rows in SQL Server with php

建立连接后我得到的响应 运行 查询是 "resource(4) of type (SQL Server Connection)"

<?php    
$serverName = "xx.xx.xx.xx";   
$uid = "sa";     
$pwd = "xxxxxxxxxx";    
$databaseName = "courierdb";   

$connectionInfo = array( "UID"=>$uid,                              
                         "PWD"=>$pwd,                              
                         "Database"=>$databaseName);   

/* Connect using SQL Server Authentication. */  

$conn = sqlsrv_connect( $serverName, $connectionInfo);

var_dump($conn);


/* Execute the query. */    
$sql = "SELECT * FROM dbo.AwbDomestics";     
$stmt = sqlsrv_query( $conn, $sql);
if( $conn === false ) {
    die( print_r( sqlsrv_errors(), true));
}
while ($row = sqlsrv_fetch_array($stmt,SQLSRV_FETCH_ASSOC))
{
    if (sqlsrv_has_rows($stmt)) {

        echo "row:<br>"; var_dump($row); echo "<br><br>";

    }
    else {
        echo "<br/>No Results were found."; 
    }

}

sqlsrv_free_stmt( $stmt);  
sqlsrv_close( $conn); 
?>        

我如何 select 数据库中的所有行都没有这种类型的“资源(4)(SQL 服务器连接)。非常感谢任何帮助。

您可以试试这个脚本。没有必要使用 sqlsrv_has_rows()。使用 sqlsrv_fetch_array() or sqlsrv_fetch()/sqlsrv_get_field() 检索数据。

<?php
/* Warnings */
sqlsrv_configure("WarningsReturnAsErrors", 1);

/* Connection */
$serverName = "xx.xx.xx.xx";   
$uid = "sa";     
$pwd = "xxxxxxxxxx";    
$databaseName = "courierdb";   
$connectionInfo = array(
    "UID" => $uid,                              
    "PWD" => $pwd,                              
    "Database" => $databaseName
);   
$conn = sqlsrv_connect(
    $serverName, 
    $connectionInfo
);
if ($conn === false) {
    die(print_r(sqlsrv_errors(), true));
}

/* Execute the query with sqlsrv_fetch_array(). */    
$sql = "SELECT * FROM dbo.AwbDomestics";     
$stmt = sqlsrv_query($conn, $sql);
if ($stmt === false) {
    die(print_r(sqlsrv_errors(), true));
}
while ($row = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)) {
    //print_r($row, true);
    foreach($row as $field => $value) {
        echo $field.": ".$value." ";
    }
    echo "\n";  
}

/* Execute the query with sqlsrv_fetch()/sqlsrv_get_field(). */    
$sql = "SELECT * FROM dbo.AwbDomestics";     
$stmt = sqlsrv_query($conn, $sql);
if ($stmt === false) {
    die(print_r(sqlsrv_errors(), true));
}
$fc = sqlsrv_num_fields($stmt);
while (sqlsrv_fetch($stmt)) {
    for($i = 0; $i < $fc; $i++) {
        echo sqlsrv_get_field($stmt, $i, SQLSRV_PHPTYPE_STRING(SQLSRV_ENC_CHAR))." ";
    }
    echo "\n";
}

/* End */
sqlsrv_free_stmt($stmt);  
sqlsrv_close($conn); 
?>

if (sqlsrv_has_rows($stmt)) 测试应该在循环周围,而不是在循环内部。

if (sqlsrv_has_rows($stmt)) {
    while ($row = sqlsrv_fetch_array($stmt,SQLSRV_FETCH_ASSOC))
    {
        echo "row:<br>"; var_dump($row); echo "<br><br>";
    }
    else {
        echo "<br/>No Results were found."; 
    }
}

要检查查询中的错误,您应该检查 $stmt 是否为 FALSE,而不是 $conn。所以改变

if ($conn == false)

if (!$stmt)