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

  • 相关阅读:
    Linux centos7修改根目录
    gitlab的安装
    windows上svn图标不显示 绿色对号
    java中的Serializable接口
    List Map Set的线程安全
    javascript中的each遍历
    jdk 1.7新特性
    jdk 1.6 新特性
    jdk1.5 新特性
    java 运算符
  • 原文地址:https://www.cnblogs.com/hellojesson/p/6379487.html
Copyright © 2020-2023  润新知