(PHP 5 >= 5.1.0, PHP 7, PHP 8, PECL pdo >= 0.1.0)
PDO::exec — 執(zhí)行一條 SQL 語句,并返回受影響的行數(shù)
$statement
): intPDO::exec() 在一個單獨的函數(shù)調(diào)用中執(zhí)行一條 SQL 語句,返回受此語句影響的行數(shù)。
PDO::exec() 不會從一條 SELECT 語句中返回結(jié)果。對于在程序中只需要發(fā)出一次的 SELECT 語句,可以考慮使用 PDO::query()。對于需要發(fā)出多次的語句,可用 PDO::prepare() 來準(zhǔn)備一個 PDOStatement 對象并用 PDOStatement::execute() 發(fā)出語句。
PDO::exec() 返回受修改或刪除 SQL 語句影響的行數(shù)。如果沒有受影響的行,則 PDO::exec() 返回 0。
此函數(shù)可能返回布爾值
false
,但也可能返回等同于 false
的非布爾值。請閱讀 布爾類型章節(jié)以獲取更多信息。應(yīng)使用
===
運算符來測試此函數(shù)的返回值。
下面例子依賴 PDO::exec() 的返回值是不正確的,其中受影響行數(shù)為 0 的語句會導(dǎo)致調(diào)用 die() :
<?php
$db->exec() or die(print_r($db->errorInfo(), true));
?>
示例 #1 發(fā)出一條 DELETE 語句
計算由一條不帶 WHERE 字句的 DELETE 語句刪除的行數(shù)。
<?php
$dbh = new PDO('odbc:sample', 'db2inst1', 'ibmdb2');
/* 刪除 FRUIT 數(shù)據(jù)表中滿足條件的所有行 */
$count = $dbh->exec("DELETE FROM fruit WHERE colour = 'red'");
/* 返回被刪除的行數(shù) */
print("Deleted $count rows.\n");
?>
以上例程會輸出:
Deleted 1 rows.