相关疑难解决方法(0)

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

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

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

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

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

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

sql indexing select join greatest-n-per-group

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

JPA Criteria API:加入另一个查询

我正在尝试使用 JPA Criteria API 构建此查询

SELECT s FROM snapshot s
INNER JOIN (
    SELECT collector_id, entity_id, MAX(timestamp) AS "timestamp"
    FROM snapshot GROUP BY collector_id, entity_id
) AS j ON s.TIMESTAMP = j.TIMESTAMP AND s.collector_id = j.collector_id AND s.entity_id = j.entity_id;
Run Code Online (Sandbox Code Playgroud)

内部 select 应该获取 3 个属性来标识快照,然后外部 select 将根据内部 select 返回的 3 个属性获取快照的所有其他属性。

我成功构建了内部选择,但是如何使用连接将外部选择与内部选择结合起来?

或者,也许有一种不同的方式来构造查询本身,不包括子查询......

编辑:

类似的问题:jpa criteria-api: join with subselect

java hibernate jpa criteria-api

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