gpt4 book ai didi

php - 区分由于错误条件导致的失败更新和由于未更改值导致的失败更新

转载 作者:行者123 更新时间:2023-11-29 05:56:48 25 4
gpt4 key购买 nike

我的问题是关于 MySQL UPDATE 语句,如果不满足 WHERE 子句中的更新条件,它返回 zero '0' 但也返回 zero '0' 如果 UPDATE 语句中声明的值也未更改并且我正在使用 mysqli_affected_rows($conn); 检查受影响的行是否有区分这两种失败的方法。

这是一个示例表:

ID(auto_increment) | music_name     | price | genre |
556785 | rock star | $30 | rap |
896785 | game of thrones| $30 | O.S.T |
116785 | i can dance | $30 | dance |

这是一个示例代码:

$query="UPDATE `songs` SET `music_name`='$name', `price`='$price' WHERE `genre`=$genre" ;
$result= mysqli_query($conn,$query);

if(mysqli_affected_rows($conn)===0)
{
$query="INSERT INTO `songs` (`music_name`,`price`,`genre`) VALUES ('$name','$price','$genre')";
$result=mysqli_query($conn,$query);
}

现在这工作正常但是当输入数据库表中已经存在的相同值时 mysqli_affected_rows();将通过运行 INSERT INTO 语句返回 zero '0',我们最终得到重复的行。

我怎样才能使这样的查询更好?无需在 UPDATE 之前先添加更多查询来选择和检查行。还有另一种选择可能使用带条件的触发器来删除重复的行?但我认为有更好的方法。

目前除了在 auto_increment 上的 ID 之外,表中没有唯一的列

最佳答案

首先,如果值相同,MySQL 将不会更新该行,因此受影响的行数将为 0。

此问题的解决方案:

$query="SELECT count(*) as cnt FROM `songs` WHERE `music_name`='$name', `price`='$price' AND `genre`=$genre" ;
/****get count from the query******/
if(count > 0 ) {
//update the table row
}
else{
//insert the table row
}

关于php - 区分由于错误条件导致的失败更新和由于未更改值导致的失败更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48686948/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com