Python 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

我在mysql中有一个数据库,我正在建立一个django项目。我有一些具有多对多关系的实体,它们通过关联表进行处理。有了django,我明白了我可以使用多对多实体来实现多对多关系,但是当关联表除了多对多关系之外还包含更多信息时,我该怎么做? 请参见下面的示例

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查找相关记录(从图片中)的可能性是否会被隐式创建?您将有机会阅读答案中的完整页面链接,并且不要忘记接受答案如果它对您有帮助,它将帮助其他对相同问题感兴趣的人