相关疑难解决方法(0)

SQL连接:选择一对多关系中的最后一条记录

假设我有一张顾客表和一张购买表.每次购买都属于一个客户.我想在一个SELECT语句中获取所有客户的列表以及他们上次购买的列表.什么是最佳做法?有关构建索引的建议吗?

请在答案中使用这些表/列名称:

  • 顾客:身份证,姓名
  • 购买:id,customer_id,item_id,日期

在更复杂的情况下,通过将最后一次购买放入客户表中,是否(性能方面)有利于对数据库进行非规范化?

如果(购买)ID保证按日期排序,是否可以通过使用类似的方式简化语句LIMIT 1

sql indexing select join greatest-n-per-group

268
推荐指数
10
解决办法
21万
查看次数

Django查询从不同类别获取最新对象

我有两个型号AB.所有B对象都有一个对象的外键A.给定一组A对象,无论如何都要使用ORM来获取B包含为每个A对象创建的最新对象的一组对象

这是一个简化的例子:

class Bakery(models.Model):
    town = models.CharField(max_length=255)

class Cake(models.Model):
    bakery = models.ForeignKey(Bakery, on_delete=models.CASCADE)
    baked_at = models.DateTimeField()
Run Code Online (Sandbox Code Playgroud)

所以我正在寻找一个可以返回美国Anytown每家面包店最新蛋糕的查询.

python django django-queryset greatest-n-per-group

72
推荐指数
4
解决办法
2万
查看次数

Django QuerySet 聚合和加入

我对 Django 很陌生,我正试图弄清楚如何解决这个问题。这是我的模型:

class Product(models.Model):
    code = models.CharField(max_length=50)
    name = models.CharField(max_length=50)

class ProductDetail(models.Model):
    product = models.ForeignKey(Product, on_delete=models.CASCADE, editable=False)
    price = models.DecimalField(max_digits=5, decimal_places=2, default=Decimal('999.99'))
    available = models.BooleanField(default=True)
    validity_tms = models.DateTimeField(default=timezone.now)
Run Code Online (Sandbox Code Playgroud)

基本上,对于每个产品,我想跟踪价格和可用性的变化。因此,每个产品都存在许多 ProductDetail。

需要时,我需要获取每个产品的codenameavailableprice字段,但只与每个产品的最大validity_tms 的 ProductDetail 相关。

这个 QuerySet 只包含我需要的部分信息:

ProductDetail.objects.values('product').annotate(max_date=Max('validity_tms'))
Run Code Online (Sandbox Code Playgroud)

我也如何检索价格可用字段?

有没有办法解决这个问题?我在模型中做错了吗?

python django django-queryset

1
推荐指数
1
解决办法
2256
查看次数