最近的一条左连接logging
想象一下,我在SqlServer中有以下3个表:
Customer (CustomerID, FirstName, LastName) Address (AddressID, CustomerID, Line1, City, State) Product (ProductID, CustomerID, Description)
一个客户可以有多个交货地址和多个产品。
我想要做的是列出由最近的地址logging确定的每个州的客户数量。 如“每个州有多less客户最后收到产品?”。 因此,我对客户以前的任何地址logging不感兴趣,只有最近的(由AddressID确定)。
State | Number of Customers -------------------------- CA | 32 GA | 12 TX | 0 OH | 18
我通常会做这样的事情:
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
但是,由于客户可能有多个地址,客户只能计入最近地址logging的状态吗?
PS以上仅仅是一个示例场景,可以轻松解释我想要实现的连接,并不能反映实际的系统devise。
尝试这个:
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 AND a.AddressID = ( SELECT MAX(AddressID) FROM Address z WHERE z.CustomerID = a.CustomerID ) WHERE p.ProductID = 101 GROUP BY a.State
没有Orders和OrderDetails表,我不知道如何做到这一点。 订单表将包括CustomerID ShippingDate和ShipToAddressID,OrderDetails将具有OrderID和ProductID。 然后,您需要一个嵌套查询来确定最近的订单(以及最近的地址),将其join订单详细信息以获得订购的产品,然后筛选您关心的产品。
你也可以尝试(假设我正确记得我的SQLServer语法):
SELECT state, count(customer_id) FROM ( SELECT p.customer_id , (SELECT TOP 1 State FROM Address WHERE Address.CustomerID = p.CustomerID ORDER BY Address.ID DESC) state FROM Product p WHERE p.ProductID = 101) GROUP BY state