相关疑难解决方法(0)

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

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

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

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

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

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

sql indexing select join greatest-n-per-group

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

左边加入的最近记录

想象一下,我在SqlServer中有以下3个表:

Customer (CustomerID, FirstName, LastName)
Address (AddressID, CustomerID, Line1, City, State)
Product (ProductID, CustomerID, Description)
Run Code Online (Sandbox Code Playgroud)

客户可以拥有多个送货地址和多个产品.

我想要做的是列出最新地址记录确定州的每个州的客户数量.例如"每个州有多少客户上次收到产品?".因此,我对客户以前的任何地址记录都不感兴趣,只对最近的地址记录感兴趣(由AddressID确定).

State | Number of Customers
--------------------------
CA    | 32
GA    | 12
TX    | 0
OH    | 18
Run Code Online (Sandbox Code Playgroud)

我通常会这样做:

SELECT a.State, count(c.CustomerID)
FROM Product p
INNER JOIN Customer c ON c.CustomerID = p.CustomerID
LEFT JOIN Address a ON a.CustomerID = c.CustomerID
WHERE p.ProductID = 101
GROUP BY a.State
Run Code Online (Sandbox Code Playgroud)

但是,由于客户可能有多个地址,客户只会被计入最新地址记录的状态?

PS以上纯粹是一个示例场景,可以轻松解释我想要实现的连接,并不反映实际的系统设计.

sql sql-server sql-server-2005

50
推荐指数
1
解决办法
4万
查看次数