如何解决Django ORM查询
我也是django
和SQL
的新手。
我需要列出供应商产品的清单,这些清单具有相对便宜的产品,然后再登录(使用相同的product_id
)才能从其他供应商处获得。
要求:Django=2.2 PostgreSQL=9.6
让我知道如何通过django-ORM
来执行此操作,以及仅使用SQL语言来编写什么代码
这是模型。
Models.py
class Product(models.Model):
name = models.CharField('product name',max_length=50)
product = models.CharField('vendor code',default=None,max_length=50,unique=True)
class Supplier(models.Model):
name = models.CharField('Supplier name',default='',max_length=50)
Class SupplierProduct(models.Model):
supplier = models.ForeignKey(Supplier,on_delete=models.CASCADE)
product = models.ForeignKey(Product,on_delete=models.CASCADE)
product_price = models.DecimalField('Price',max_digits=11,decimal_places=2)
availability = models.BooleanField(default=False)
Views.py
def foo(request):
user = request.user
解决方法
您可以使用Exists
subquery [Django-doc]:
from django.db.models import Exists,OuterRef,Q
SupplierProduct.objects.filter(
Exists(SupplierProduct.objects.filter(
~Q(supplier_id=OuterRef('supplier_id')),product_id=OuterRef('product_id'),product_price__lt=OuterRef('product_price')
))
)
因此,我们保留了SupplierProduct
,其中存在SupplierProduct
,其中supplier
不同,product_id
相同且价格较低。
在django-3.0之前,您先注释,然后过滤:
Django-2.2 and older
from django.db.models import Exists,Q
SupplierProduct.objects.annotate(
has_cheaper=Exists(SupplierProduct.objects.filter(
~Q(supplier_id=OuterRef('supplier_id')),product_price__lt=OuterRef('product_price')
))
).filter(has_cheaper=True)
,
SupplierProduct.objects.annotate(
has_cheaper=Exists(SupplierProduct.objects.filter(
Q(supplier__name=user),~Q(supplier_id=OuterRef('supplier_id')),product_price__gt = OuterRef('product_price')
)
)
).filter(availability=True,has_cheaper=True)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。