mssql_fetch_array没有显示所有结果-问题出在哪里

时间:2019-06-13 10:39:55

标签: php sql sql-server

我将加入主题-我有一个SQL查询:

SELECT a.tw_Nazwa, c.st_Stan, d.zd_Glowne , d.zd_Zdjecie, a.tw_Id, a.tw_Symbol,e.cht_IdCecha,b.tc_CenaNetto1,b.tc_CenaBrutto1
FROM tw__Towar  a
LEFT JOIN tw_CechaTw  e ON a.tw_Id = e.cht_IdTowar
LEFT JOIN tw_Cena  b ON a.tw_Id = b.tc_IdTowar
LEFT JOIN tw_Stan c ON b.tc_IdTowar=c.st_TowId
LEFT JOIN tw_ZdjecieTw  d ON d.zd_IdTowar=c.st_TowId
WHERE tw_SklepInternet = 1 AND st_MagId = 1 

该查询应该有261个结果,这就是Dbeaver程序对数据库进行的处理。

使用:

$getResults = sqlsrv_query($conn1, $Query);
if( $getResults === false ) {
    die( print_r( sqlsrv_errors(), true) );

}

while ($row = sqlsrv_fetch_array($getResults, SQLSRV_FETCH_ASSOC)) {
//blablabla
$i++;
}

print $i //is showing only 12 results

这是可行的,但不是解决方案:


    for($i=0;$i<=260;$i++){
    $row = sqlsrv_fetch_array($getResults, SQLSRV_FETCH_ASSOC)
    //blablabla
    $i++;
    }

获取数组时出错。


    Array
    (
        [0] => Array
            (
                [0] => IMSSP
                [SQLSTATE] => IMSSP
                [1] => -22
                [code] => -22
                [2] => There are no more rows in the active result set.  Since this result set is not scrollable, no more data may be retrieved.
                [message] => There are no more rows in the active result set.  Since this result set is not scrollable, no more data may be retrieved.
            )

    )

错误在哪里以及如何解决。

1 个答案:

答案 0 :(得分:0)

$params = array();
$options =  array( "Scrollable" => SQLSRV_CURSOR_KEYSET );

$row_count = sqlsrv_num_rows( $stmt );

正在工作-THX;)