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最大的‘重复数据’即可!

  • 相关阅读:
    实用工具分享
    美国西储大学轴承数据解读
    CSDN去广告插件
    [教程]SPSS for Mac 安装教程
    [教程]Ubuntu 安装 Docker CE
    [教程]Windows操作系统下安装Ubuntu虚拟机
    Chrome视频解析插件
    [软件]MATLAB小波包的分解与重构
    [信号处理]奈奎斯特采样定理
    [软件]LabVIEW编程实例:如何通过TCP协议进行数据通信
  • 原文地址:https://www.cnblogs.com/hellojesson/p/6379487.html
Copyright © 2011-2022 走看看