按位运算符的MySQL状态交换

时间:2009-09-16 11:14:33

标签: php mysql replace status swap

我正在寻找一种解决方案/最佳做法来为状态标志交换值。

mysql中的状态INT(3)有一些值,我希望能够交换LIVE和NOT_LIVE值,而不会中断其中的其他按位值。

如果是标志字段,如0或1,则很容易:

'status' NOT 'status'

我想知道是否有一种方法可以基于两个值(x,y)进行交换 - 没有太多的代码逻辑,就像上面的代码一样。当然我可能在做梦,只需要恢复到SELECT查询,if语句和UPDATE ......

任何想法?

3 个答案:

答案 0 :(得分:1)

“交换[ping] LIVENOT_LIVE值”是什么意思?如果LIVE是一个设置/未设置的位,那么你要寻找的是一个按位NAND。例如,如果其值为8并且您想取消

UPDATE table SET status = status &~ 8

它将取消设置值为8的位。如果LIVENOT_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