在连接操作中选择不同的记录

20

我有两个MySQL表 - 一个销售表:

+----------------+------------------------------+------+-----+---------+-------+
| Field          | Type                         | Null | Key | Default | Extra |
+----------------+------------------------------+------+-----+---------+-------+
| StoreId        | bigint(20) unsigned          | NO   | PRI | NULL    |       |
| ItemId         | bigint(20) unsigned          | NO   |     | NULL    |       |
| SaleWeek       | int(10) unsigned             | NO   | PRI | NULL    |       |
+----------------+------------------------------+------+-----+---------+-------+

还有一个物品表:

+--------------------+------------------------------+------+-----+---------+-------+
| Field              | Type                         | Null | Key | Default | Extra |
+--------------------+------------------------------+------+-----+---------+-------+
| ItemId             | bigint(20) unsigned          | NO   | PRI | NULL    |       |
| ItemName           | varchar(100)                 | NO   |     | NULL    |       |
+--------------------+------------------------------+------+-----+---------+-------+

销售表格包含每个 ItemID 的多条记录 - 每个 SaleWeek 一条。我想通过连接这两个表来选择所有已售出的物品,如下所示:

SELECT items.ItemName, items.ItemId FROM items
JOIN sales ON items.ItemId = sales.ItemId 
WHERE sales.StoreID = ? ORDER BY sales.SaleWeek DESC;
然而,这将基于每个销售周的多个条目返回多个ItemId值。我是否可以执行一个DISTINCT选择来仅返回一个ItemID - 我不想查询最新的SaleWeek,因为某些项目可能没有最新的SaleWeek的条目,所以我需要获取最后一次销售。我需要指定DISTINCT还是使用LEFT OUTER JOIN或其他方法?

1
你尝试过DISTINCT吗?这可能会取决于您使用的DBMS而使您的排序出现问题。 - BlueRaja - Danny Pflughoeft
4个回答

33

DISTINCT关键字可以达到你要的效果:

SELECT DISTINCT items.ItemName, items.ItemId FROM items
JOIN sales ON items.ItemId = sales.ItemId 
WHERE sales.StoreID = ? ORDER BY sales.SaleWeek DESC;

这将仅返回不重复的items.ItemName, items.ItemId元组。


12

您对销售周的评论也很重要。如果想要最近的一周,可以尝试使用 GROUP BY。

SELECT 
      items.ItemName, 
      items.ItemId,
      max( Sales.SaleWeek ) MostRecentSaleWeek
   FROM 
      items JOIN sales ON items.ItemId = sales.ItemId
   WHERE 
      sales.StoreID = ? 
   GROUP BY
      items.ItemID,
      items.ItemName
   ORDER BY
      MostRecentSaleWeek,   -- ordinal column number 3 via the MAX() call
      items.ItemName

如果你想基于第三列排序,你可能需要将ORDER BY更改为序数 3 的列引用。此查询将为您提供每个不同的物品以及它最近出售的周数。


2
    SELECT  u.user_name,u.user_id, u.user_country,u.user_phone_no,ind.Industry_name,inv.id,u.user_email
    FROM invitations inv
    LEFT JOIN users u
    ON inv.sender_id = u.user_id
    LEFT JOIN employee_info ei
    ON inv.sender_id=ei.employee_fb_id   
    LEFT JOIN industries ind
    ON ei.industry_id=ind.id
    WHERE inv.receiver_id='XXX'
    AND inv.invitation_status='0'
    AND inv.invitati

on_status_desc='PENDING'
GROUP BY (user_id)

1
我们可以使用这个:
INSERT INTO `test_table` (`id`, `name`) SELECT DISTINCT 
    a.`employee_id`,b.`first_name` FROM `employee_leave_details`as a INNER JOIN 
    `employee_register` as b ON a.`employee_id` = b.`employee_id`

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接