繁体   English   中英

Django将字段添加到查询集

[英]Django add field to query set

嗨,我的 django 项目中有 3 个模型,当用户发送请求时,我有他的dealer_id我需要返回查询集,其中包含有关 Material 表中的材料的信息,并为每一行添加最后一个模型的 discount_percent,其中dealer_id = 当前的dealer_id 和行 id。 如果你有答案,请帮助我。

楷模

class Material(models.Model):
    id = models.AutoField(primary_key=True)
    color = models.IntegerField() 
    name = models.CharField(max_length=100)
    material_width = models.IntegerField()
    price = models.BigIntegerField(default=0)  

class Dealer(models.Model):
    id = models.AutoField(primary_key=True)
    dealer_name = models.CharField(max_length=100)
    dealer_phone = models.CharField(max_length=13, unique=True)
    dealer_email = models.CharField(max_length=150, null=False, unique=True)
    dealer_firm_name = models.CharField(max_length=100, null=True)
    dealer_address = models.CharField(max_length=100, null=True)
    dealer_unp = models.CharField(max_length=9, null=True)
    dealer_amount = models.FloatField(default=0.0)
    user_id = models.BigIntegerField(unique=True) 

class MaterialDealerPrice(models.Model):
    id = models.AutoField(primary_key=True)
    dealer_id = models.BigIntegerField(null=False)
    material_id = models.BigIntegerField(null=False)
    discount = models.FloatField(null=True, default=0.0)

这看起来像是通过运行 inspectdb 自动创建的一组模型。 您应该始终将该输出视为初稿; 需要手动完成很多工作才能将其整理好。

首先,您的 MaterialDealerPrice 模型需要有 Dealer 和 Material 的外键:

class MaterialDealerPrice(models.Model):
    dealer = models.ForeignKey('Dealer', null=False)
    material = models.ForeignKey('Material', null=False)
    discount = models.FloatField(null=True, default=0.0)

其次,您应该认识到这个模型实际上是多对多关系的直通表。

class Material(models.Model):
    ...
    dealers = models.ManyToManyField('Dealer', through='MaterialDealerPrice')

现在,您应该能够在查询中遵循这些关系。 不幸的是,您的问题不够清楚,无法知道您真正想要做什么; 您应该给出所需输出的示例。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM