在字段UPDATE如果值已经设置,将其设置为其他内容?

时间:2009-06-12 07:18:53

标签: mysql sql-update

我知道我可以通过几行PHP轻松完成这项工作,但我希望MYSQL中有一个方法可以做到这一点;我认为有,但我找不到任何运气。

基本上我想这样做:

UPDATE fieldName SET status='1'
if status='1', SET status='2'

所以第二行显然不是真正的代码,但这就是我想要做的。将字段更新为值,如果该字段已经等于该值,则将其更新为不同的值。

2 个答案:

答案 0 :(得分:5)

这会有用吗?

UPDATE table SET status = IF(status = 1, 2, 1) WHERE ...;

基本上,如果状态等于1,那么将其设置为2,否则保持为1.但是如果这就是你想要做的那样你也可以这样做:

UPDATE table SET status = 2 WHERE status = 1;

答案 1 :(得分:1)

如果您想要一个像切换按钮一样的字段,请尝试以下方法:

UPDATE table SET status = ABS(status - 1) WHERE...

这种方式每次更新状态时都会在0到1之间切换