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

  • 相关阅读:
    android architecture
    java求解两个字符串之间的编辑距离
    URL和URI的区别
    java源码解析之qdox
    java中Random实现原理
    java中ThreadLocal入门
    java中多线程之Future入门
    java中类加载器入门
    java中正则表达式的group用法
    java反射调用main方法踩坑
  • 原文地址:https://www.cnblogs.com/hellojesson/p/6379487.html
Copyright © 2011-2022 走看看