(Aşağıdaki kodun tamamı gerçek kodun basitleştirilmiş bir temsilidir).Model alanları arasında basit aritmetik ile Django sorgu ve başka bir modelden alan ile karşılaştırma
Aşağıdaki Django modellerini varsa: -
class Material(models.Model):
name = models.CharField(max_length=110)
class OrderDetail(models.Model):
material = models.ForeignKey(Material)
order_quantity = models.IntegerField()
quantity_delivered = models.IntegerField(null=True, blank=True)
is_open = models.BooleanField()
is_active = models.BooleanField()
class MaterialRequirement(models.Model):
material = models.ForeignKey(Material)
quantity = models.IntegerField()
Yanımda MaterialRequirement
modelinin bir örneğini var, hadi material_requirement
diyelim.
1. material = material_requirement.material
2. is_open = True
3. is_active = True
4. order_quantity > quantity_delivered
5. material_requirement.quantity <= order_quantity - quantity_delivered
Sorum aşağıda benim ORM sorguda 5 seçim kriterlerini dahil nasıl olduğunu: - Ben aşağıdaki ölçütleri karşılayan OrderDetail
nesneleri almak için çalışıyorum.
order_details = order_detail.extra(where=["order_quantity - quantity_delivered <= %d" % material_requirement.quantity]))