亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何檢查pdo更新查詢中是否有任何列值已更改

如何檢查pdo更新查詢中是否有任何列值已更改

PHP
catspeake 2021-05-01 10:08:25
我需要檢查使用PDO更新記錄時是否有任何列值已更改。我在下面解釋我的查詢。$qry ="UPDATE cb_driver_info        SET owner_id=:owner_id,           email=:email,           mobile=:mobile,           image=:image        WHERE id=:driver_id";$stmt = $db->prepare($qry);$stmt->bindParam(':owner_id', htmlspecialchars(strip_tags($owner_id)));$stmt->bindParam(':email', htmlspecialchars(strip_tags($email)));$stmt->bindParam(':mobile', htmlspecialchars(strip_tags($mobile)));$stmt->bindParam(':image', htmlspecialchars(strip_tags($image)));$stmt->bindParam(':driver_id', htmlspecialchars(strip_tags($driver_id)));$stmt->execute();在這里,我正在更新記錄。我需要檢查是否有任何列值在更新時被破壞,然后它將更新return 1,如果同一條記錄再次在更新,它將更新return 0。
查看完整描述

2 回答

?
鴻蒙傳說

TA貢獻1865條經驗 獲得超7個贊

根據的手冊中rowCount()的注釋,

當更新具有相同值的Mysql表時,什么都沒有受到真正的影響,因此rowCount將返回0。

的PHP手冊中未明確記錄rowCount()。但是,它記錄在MySQLUPDATE文檔中,

如果將列設置為其當前值,MySQL會注意到這一點,并且不會對其進行更新。

結合

UPDATE返回實際更改的行數。

但是,請注意,如果PDO::MYSQL_ATTR_FOUND_ROWS => true在定義PDO對象時添加該選項,則會更改此行為。使用該選項,它將返回受影響的行數,而不管它們的值實際上是否已更新(因此,只要發現匹配WHERE條件的記錄,即使值沒有更改,它也將返回1 )。

所以你的代碼最終會被

$stmt->execute();
return $stmt->rowCount() ? 1 : 0;


查看完整回答
反對 回復 2021-05-14
?
元芳怎么了

TA貢獻1798條經驗 獲得超7個贊

您可以使用rowCount()。如果某行受更新影響(即任何列值已更改),則該行將計為1。從MySQL手冊

如果將列設置為其當前值,MySQL會注意到這一點,并且不會對其進行更新。
UPDATE返回實際更改的行數。

你之后$stmt->execute()使用

if ($stmt->rowCount()) {

    // some rows changed

    // do something

}

如果您只想在發生更新時返回true / false值,則可以


return $stmt->rowCount() > 0;

或者,如果您未使用嚴格的類型匹配(例如===),則只需


return $stmt->rowCount();


查看完整回答
反對 回復 2021-05-14
  • 2 回答
  • 0 關注
  • 212 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號