2024 年日本 PHP 研討會

sqlsrv_free_stmt

(沒有版本資訊,可能只在 Git 中)

sqlsrv_free_stmt釋放指定陳述式的所有資源

說明

sqlsrv_free_stmt(資源 $stmt): 布林值

釋放指定陳述式的所有資源。在呼叫 sqlsrv_free_stmt() 後,該陳述式將無法再使用。如果對正在執行且會更改伺服器狀態的陳述式呼叫 sqlsrv_free_stmt(),則陳述式執行將會終止並回復原狀。

參數

stmt

要釋放資源的陳述式。請注意,null 是一個有效的參數值。這允許在腳本中多次呼叫此函式。

傳回值

成功時傳回 true,失敗時傳回 false

範例

範例 #1 sqlsrv_free_stmt() 範例

<?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));
}

$stmt = sqlsrv_query( $conn, "SELECT * FROM Table_1");
if(
$stmt === false ) {
die(
print_r( sqlsrv_errors(), true));
}

/*-------------------------------
在此處理查詢結果。
-------------------------------*/

/* 釋放陳述式資源。 */
sqlsrv_free_stmt( $stmt);

?>

注意事項

sqlsrv_free_stmt()sqlsrv_cancel() 的主要區別在於,使用 sqlsrv_prepare() 建立的陳述式資源,如果使用 sqlsrv_cancel() 取消,則可以重新執行。使用 sqlsrv_free_stmt() 取消的陳述式資源則無法重新執行。

另請參閱

新增筆記

使用者貢獻的筆記 1 則筆記

匿名
9 年前
如果您不小心以無效的 $stmt 資源呼叫此函式,您可能會看到非預期的致命錯誤。

我在清理一些程式碼時遺漏了這裡的呼叫,這導致我的 IIS 伺服器產生錯誤 500 資源未找到的錯誤。此外,它似乎只影響某些使用者,而不是所有使用者,而且我無法找出為什麼只有特定使用者在所有使用者都呼叫它時才會發生錯誤。
To Top