我知道我可以通过几行PHP轻松完成这项工作,但我希望MYSQL中有一个方法可以做到这一点;我认为有,但我找不到任何运气。
基本上我想这样做:
UPDATE fieldName SET status='1'
if status='1', SET status='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之间切换