zoukankan      html  css  js  c++  java
  • Django设置联合唯一约束 -- migrate时报错处理

    异常信息:

       a unique database constraint for 2 or more fields together

    场景描述:

    对于ORM中多对多关系的中间表,如果该关系表是手动创建的,建表的时候,两个字段没有添加联合唯一约束;

    系统运行一段时间后,若是需求变更,需要对其增加联合唯一约束,而当前的关系表中可能已存在重复数据了,那么在添加联合唯一约束,执行数据同步操作migrate的时候,就会报错;这时,可以参考这种处理方式。

    推荐一篇博客:http://shineforever.blog.51cto.com/1429204/1729286

    一个表的model中,根据生产环境需要,需要设置site和对应的cdn服务器ip是联合唯一的,最开始创建表的时候,没有考虑到这个问题,后来设置了联合唯一约束 unique_together,在同步数据migrate的时候,报错:a unique database constraint for 2 or more fields together

    很明显数据库中有很多这两个字段重复的数据,所以要删除重复数据后再migrate就没问题了,但是怎么删除这些数据呢?

    通过以下两个步骤即可:

    1)CREATE TEMPORARY TABLE tmp_table SELECT * FROM 目标表;
    2)delete from 目标表 where id not in (select max(id) from tmp_table group by cdn_ipaddr,site_id);

    说明:

    创建临时表,把目标表的数据复制到临时表中;

    删除目标表中数据,只留id最大的‘重复数据’即可!

  • 相关阅读:
    动画效果
    iOS蓝牙4.0
    讯飞语音接口使用
    Xcode添加注释
    CocoaPods安装
    mac os 下打开FTP服务器
    画面渲染:实时渲染(Real-time Rendering)、离线渲染(Offline Rendering)[转]
    Unity3D笔记 英保通九 创建数
    Unity3D笔记 英保通八 关节、 布料、粒子系统
    Unity3D 记第二次面试
  • 原文地址:https://www.cnblogs.com/hellojesson/p/6379487.html
Copyright © 2011-2022 走看看