您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – Django双向ManyToMany – 如何防止在第二个模型上创建表?

5b51 2022/1/14 8:22:25 python 字数 1503 阅读 513 来源 www.jb51.cc/python

我有两个模型,每个都有一个共享的ManyToMany,使用db_table字段.但是,如何防止syncdb尝试创建共享表,第二个模型? class Model1(models.Model): othermodels = ManyToManyField('Model2', db_table='model1_model2', related_name='model1_model2') cla

概述

class Model1(models.Model):
    othermodels = ManyToManyField('Model2',db_table='model1_model2',related_name='model1_model2')

class Model2(models.model):
    othermodels = ManyToManyField('Model1',related_name='model2_model1')

它在我的开发环境中工作得很好,因为有些表格是零碎地创建出来的,因为我将其全部构建出来.但是从一个数据库,syncdb throws:
_MysqL_exceptions.OperationalError :((1050,“Table”model1_model2“已经存在”)

有没有一个标记,我从第二个模型的字段中丢失,以防止重复的表创建?还是我这样做完全错了?

class Test1(models.Model):
    tests2 = models.ManyToManyField('Test2',blank=True)

class Test2(models.Model):
    tests1 = models.ManyToManyField('Test1',through=Test1.tests2.through,blank=True)

总结

以上是编程之家为你收集整理的python – Django双向ManyToMany – 如何防止在第二个模型上创建表?全部内容,希望文章能够帮你解决python – Django双向ManyToMany – 如何防止在第二个模型上创建表?所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶