Python Django和许多领域
我在mysql中有一个数据库,我正在建立一个django项目。我有一些具有多对多关系的实体,它们通过关联表进行处理。有了django,我明白了我可以使用多对多实体来实现多对多关系,但是当关联表除了多对多关系之外还包含更多信息时,我该怎么做? 请参见下面的示例Python Django和许多领域,python,django,django-models,Python,Django,Django Models,我在mysql中有一个数据库,我正在建立一个django项目。我有一些具有多对多关系的实体,它们通过关联表进行处理。有了django,我明白了我可以使用多对多实体来实现多对多关系,但是当关联表除了多对多关系之外还包含更多信息时,我该怎么做? 请参见下面的示例 CREATE TABLE `products` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` char(150) DEFAULT NULL ...) CREATE
CREATE TABLE `products` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`name` char(150) DEFAULT NULL ...)
CREATE TABLE `pictures` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`filename` char(100) NOT NULL ... )
CREATE TABLE `products_pictures` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`fk_products_id` int(11) unsigned NOT NULL,
`fk_pictures_id` int(11) unsigned NOT NULL,
`priority` tinyint(4) unsigned DEFAULT NULL,
`relation` varchar(25) DEFAULT 'same product family' ... )
例如,您可以使用选项
class Products(models.Model):
name = models.CharField(max_length=128)
pictures = models.ManyToManyField(
Pictures,
through='ProductsPictures',
)
class ProductsPictures(models.Model):
product = models.ForeignKey(Products, on_delete=models.CASCADE)
picture = models.ForeignKey(Pictures, on_delete=models.CASCADE)
description = models.CharField(max_length=128)
谢谢你的提示!Pictures表应该具有相同的关系吗(manytomy with through=ProductsPictures)?或者通过Django查找相关记录(从图片中)的可能性是否会被隐式创建?您将有机会阅读答案中的完整页面链接,并且不要忘记接受答案如果它对您有帮助,它将帮助其他对相同问题感兴趣的人