【问题标题】:Select distinct records on a join在连接中选择不同的记录
【发布时间】:2011-01-05 07:50:34
【问题描述】:

我有两个 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    |       |
+--------------------+------------------------------+------+-----+---------+-------+

sales 表包含每个 ItemID 的多条记录 - 每个 SaleWe​​ek 一条记录。我想通过像这样加入两个表来选择所有出售的商品:

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

但是,这会根据每个 SaleWe​​ek 的多个条目返回多个 ItemId 值。我可以做一个独特的选择只返回一个 ItemID - 我不想查询最新的 SaleWe​​ek 因为有些项目可能没有最新的条目SaleWe​​ek 所以我需要获得最后一笔销售。我是否需要指定 DISTINCT 或使用 LEFT OUTER JOIN 或其他什么?

【问题讨论】:

  • 您尝试过 DISTINCT 吗?根据您使用的 DBMS,它可能会搞砸您的订购...

标签: mysql select join distinct


【解决方案1】:

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 元组。

【讨论】:

    【解决方案2】:

    您也对销售周发表了评论。并且想要最近一周,您可能想尝试使用 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】:
          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)
      

      【讨论】:

        【解决方案4】:

        我们可以使用这个:

        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`
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 2018-03-18
          • 1970-01-01
          • 2019-05-15
          • 1970-01-01
          • 2021-08-22
          • 1970-01-01
          • 2015-09-09
          相关资源
          最近更新 更多