mysql 互换两行_php – 在MySQL中交换两行的值而不违反唯一约束?

我试过这段代码

UPDATE testing_table t1

INNER JOIN testing_table t2 ON (t1.id, t2.id) IN ((1, 2),(2, 1))

SET t1.emp_id = t2.emp_id

但似乎有这个错误

#1062 – Duplicate entry ‘3’ for key ’emp_id’

让我知道如何交换2列vales而不违反mysql中的唯一约束

最佳答案 在MySql中,这并不容易,因为它在更新期间检查每个单独记录的唯一约束,而不是在最后(仅).

因此,为了允许交换列的值,您需要允许列获取不会与任何约束冲突的临时值.因此,如果您有一个具有外键约束的列,并且也不允许空值,那么在所有可能的情况下都很难找到这样的值.

对于以下解决方案,必须允许空值.如果它们当前不是,则首先发出此语句以允许emp_id列为null:

alter table testing_table modify column emp_id int null;

然后:

start transaction;

update testing_table

set emp_id = null

where id = 1 and if(@emp1 := emp_id, 1, 1)

or id = 2 and if(@emp2 := emp_id, 1, 1);

update testing_table

set emp_id = if(id = 1, @emp2, @emp1)

where id in (1, 2);

commit;

说明

这将首先将值设置为null,同时将其先前的值存储在@ emp1和@ emp2中,并使用这些变量中保留的值更新相同的记录,但是要交换.

第一个更新语句中的ifs用于确保赋值返回true表达式并使where条件成功.另请注意,短路评估将确保仅在和运算符的左侧评估为true时才会发生这些分配.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值