我正在寻找一种解决方案/最佳做法来为状态标志交换值。
mysql中的状态INT(3)有一些值,我希望能够交换LIVE和NOT_LIVE值,而不会中断其中的其他按位值。
如果是标志字段,如0或1,则很容易:
'status' NOT 'status'
我想知道是否有一种方法可以基于两个值(x,y)进行交换 - 没有太多的代码逻辑,就像上面的代码一样。当然我可能在做梦,只需要恢复到SELECT查询,if语句和UPDATE ......
任何想法?
答案 0 :(得分:1)
“交换[ping] LIVE
和NOT_LIVE
值”是什么意思?如果LIVE
是一个设置/未设置的位,那么你要寻找的是一个按位NAND。例如,如果其值为8并且您想取消它
UPDATE table SET status = status &~ 8
它将取消设置值为8的位。如果LIVE
和NOT_LIVE
是两个不同的位,则需要设置一个(OR)并取消设置另一个(NAND)。在设置NOT_LIVE
(8)
LIVE
(4)
UPDATE table SET status = (status &~ 4) | 8
如果status
只能有两个值,那么您需要的是添加这两个值,然后减去status
。例如,如果两个值是1和2
UPDATE table SET status = (1 + 2) - status
当然你可以写
UPDATE table SET status = 3 - status
请注意,如果status
取任何其他值,则会失败。你可以通过仅改变status
来避免这种情况,如果它是两者中的一个。
UPDATE table SET status = 3 - status WHERE status IN (1, 2)
在这种情况下,如果status
既不是LIVE
也不是NOT_LIVE
,则不会更改。
答案 1 :(得分:1)
所以你的值是1和2,但你想要点式翻转?这是行不通的,因为1和2设置了不同的位!
试试这个:
UPDATE table SET status = CASE status WHEN 1 THEN 2 ELSE 1 END
答案 2 :(得分:0)
您需要case statement此处:
UPDATE table SET status = CASE
WHEN status = 1 THEN 2
WHEN status = 2 THEN 3
ELSE 1
END CASE
或者,如果您愿意,可以使用if statement:
UPDATE table SET status =
IF status = 1 THEN 2
ELSEIF status = 2 THEN 3
ELSE 1
END IF