sqlsrv_fetch

(无版本信息可用,可能只在 Git 中)

sqlsrv_fetch使结果集中的下一行可供读取

说明

sqlsrv_fetch(资源 $stmt, 整数 $row = ?, 整数 $offset = ?): 混合

使结果集中的下一行可供读取。使用 sqlsrv_get_field() 读取行的字段。

参数

stmt

通过执行 sqlsrv_query()sqlsrv_execute() 创建的语句资源。

row

要访问的行。此参数只能在指定语句使用可滚动游标准备的情况下使用。在这种情况下,此参数可以采用以下值之一

  • SQLSRV_SCROLL_NEXT
  • SQLSRV_SCROLL_PRIOR
  • SQLSRV_SCROLL_FIRST
  • SQLSRV_SCROLL_LAST
  • SQLSRV_SCROLL_ABSOLUTE
  • SQLSRV_SCROLL_RELATIVE

offset

如果 row 参数设置为 SQLSRV_SCROLL_ABSOLUTESQLSRV_SCROLL_RELATIVE,则指定要访问的行。请注意,结果集中的第一行索引为 0。

返回值

如果成功检索到结果集的下一行,则返回 true;如果发生错误,则返回 false;如果结果集中没有更多行,则返回 null

范例

范例 #1 sqlsrv_fetch() 范例

以下示例演示如何使用 sqlsrv_fetch() 检索一行,并使用 sqlsrv_get_field() 获取行字段。

<?php
$serverName
= "serverName\sqlexpress";
$connectionInfo = array( "Database"=>"dbName", "UID"=>"username", "PWD"=>"password");
$conn = sqlsrv_connect( $serverName, $connectionInfo);
if(
$conn === false ) {
die(
print_r( sqlsrv_errors(), true));
}

$sql = "SELECT Name, Comment
FROM Table_1
WHERE ReviewID=1"
;
$stmt = sqlsrv_query( $conn, $sql);
if(
$stmt === false ) {
die(
print_r( sqlsrv_errors(), true));
}

// 使结果集中的第一行(在本例中也是唯一一行)可供读取。
if( sqlsrv_fetch( $stmt ) === false) {
die(
print_r( sqlsrv_errors(), true));
}

// 获取行字段。字段索引从 0 开始,必须按顺序检索。
// sqlsrv_get_field 不支持按名称检索行字段。
$name = sqlsrv_get_field( $stmt, 0);
echo
"$name: ";

$comment = sqlsrv_get_field( $stmt, 1);
echo
$comment;
?>

参见

添加注释

用户贡献的注释

此页面没有用户贡献的注释。
To Top