4

最近、PHP アプリを mssql から sqlsrv に切り替えましたが、引き続きいくつかのカスタム関数を使用してすべての SQL 要求を処理したいと考えています。エラーが発生する

警告: sqlsrv_fetch_array(): 2 は有効な ss_sqlsrv_stmt リソースではありません...

次の関数を使用してすべての sqlsrv_query() 呼び出しを処理する場合:

<?php
function tko_query($sql)
{
    //Check for db connection
    $serverName = "server\sqlexpress";
    $connectionInfo = array( "Database"=>"db", "UID"=>"uid", "PWD"=>"pwd");
    $conn = sqlsrv_connect( $serverName, $connectionInfo );
    if( $conn === false ) {
        die( print_r( sqlsrv_errors(), true));
    }

    return sqlsrv_query($conn,$sql, array(), array('Scrollable' => 'buffered'));
}


$sql = "SELECT * FROM jobs";
$stmt = tko_query($sql);

while( $row = sqlsrv_fetch_array( $stmt, SQLSRV_FETCH_ASSOC) ) 
{
   echo $row['name']."<br />";
}

sqlsrv_free_stmt( $stmt);
?>
4

1 に答える 1