如果您需要良好的性能,请尽量避免使用此函数。在选项中指定“Scrollable”会使您的查询花费很长时间才能运行。如果您的结果包含少于 5000 行(在不同的硬件上可能会有所不同),则不使用“Scrollable”并在 php 中循环遍历它们更快。
如果您需要检查结果是否包含行,请使用“sqlsrv_has_rows()”,此函数无需“Scrollable”。删除所有“Scrollable”查询后,我的页面加载时间从 900 毫秒缩短到 60 毫秒。
为了演示,这是一个返回 100 行的查询
<?php
for($i = 0; $i < 100; $i++) {
$q = "SELECT sku,name FROM product WHERE visible = 1";
$result = sqlsrv_query($db,$q,array(), array( "Scrollable" => SQLSRV_CURSOR_KEYSET ));
while($row = sqlsrv_fetch_array($result)) {}
}
?>
这大约需要 10 秒!那是 10 qps..
现在如果我们删除“Scrollable”
<?php
for($i = 0; $i < 100; $i++) {
$q = "SELECT sku,name FROM product WHERE visible = 1";
$result = sqlsrv_query($db,$q);
while($row = sqlsrv_fetch_array($result)) {}
}
?>
这将在 300 毫秒内运行,大约 334 qps!