首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Django:通过具有(唯一)复合键的表实现多对多

Django:通过具有(唯一)复合键的表实现多对多
EN

Stack Overflow用户
提问于 2010-06-22 17:01:44
回答 2查看 3.1K关注 0票数 6

我有一个遗留数据库,它有一个存储多对多关系的表,但没有一个主键列。有没有办法说服Django使用它呢?

示意性:

代码语言:javascript
复制
Product 1<---->* Labeling *<---->1 Label

Django表使用(product_id,label_id)作为复合主键,我看不到任何方法来通知Labeling这一点。(仅仅使用through就可以得到Unknown column 'labeling.id' in 'field list'。)

是否需要回退到自定义SQL?还是我错过了什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-07-31 16:28:52

如果将unique_together添加到多对多表的模型中,Django将使用这些列,而不需要名为id的主键。

票数 1
EN

Stack Overflow用户

发布于 2010-06-22 17:36:40

希望这能帮到你,

http://docs.djangoproject.com/en/dev/ref/models/options/#unique-together

http://docs.djangoproject.com/en/dev/ref/models/fields/#django.db.models.Field.db_index

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3091665

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档