ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

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

2019-07-02 09:03:31  阅读:283  来源: 互联网

标签:php mysql unique-constraint swap


我试过这段代码

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;

SQL fiddle.

说明

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

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

标签:php,mysql,unique-constraint,swap
来源: https://codeday.me/bug/20190702/1354424.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有