为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

慕的地10843 2019-08-09 10:36:58
SQL连接:选择一对多关系中的最后一条记录假设我有一张顾客表和一张购买表。每次购买都属于一个客户。我想在一个SELECT语句中获取所有客户的列表以及他们上次购买的列表。什么是最佳做法?有关构建索引的建议吗?请在答案中使用这些表/列名称:顾客:身份证,姓名购买:id,customer_id,item_id,日期在更复杂的情况下,通过将最后一次购买放入客户表中,是否(性能方面)有利于对数据库进行非规范化?如果(购买)ID保证按日期排序,是否可以通过使用类似的方式简化语句LIMIT 1?
查看完整描述

3 回答

?
慕慕森

TA贡献1856条经验 获得超17个赞

您尚未指定数据库。如果它是允许分析函数的那个,那么使用这种方法可能比GROUP BY更快(在Oracle中肯定更快,在SQL Server后期版本中更快可能更快,不了解其他版本)。

SQL Server中的语法是:

SELECT c.*, p.*FROM customer c INNER JOIN 
     (SELECT RANK() OVER (PARTITION BY customer_id ORDER BY date DESC) r, *
             FROM purchase) pON (c.id = p.customer_id)WHERE p.r = 1


查看完整回答
反对 回复 2019-08-09
  • 3 回答
  • 0 关注
  • 1481 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信