亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

SQLJoin:選擇一對多關系中的最后一個記錄。

SQLJoin:選擇一對多關系中的最后一個記錄。

阿晨1998 2019-07-05 18:41:30
SQLJoin:選擇一對多關系中的最后一個記錄。假設我有一張顧客表和一張購物表。每次購買都屬于一個客戶。我想在一個SELECT語句中獲得所有客戶的列表以及他們最后一次購買。什么是最佳做法?對建立索引有什么建議嗎?請在您的答復中使用以下表/列名稱:顧客:ID,姓名采購:ID,Customer_id,Item_id,日期在更復雜的情況下,通過將最后一次購買放到Customer表中,會(從性能上講)是否有利于數據庫的去或化?如果(購買)id保證按日期排序,那么這些語句是否可以通過使用以下內容來簡化LIMIT 1?
查看完整描述

3 回答

?
溫溫醬

TA貢獻1752條經驗 獲得超4個贊

您還沒有指定數據庫。如果是允許分析功能的方法,那么使用這種方法的速度可能比組快一個(在Oracle中肯定更快,在SQLServer后期版本中可能更快,不知道其他)。

SQLServer中的語法為:

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-07-05
  • 3 回答
  • 0 關注
  • 1069 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號