Select distinct registros en una combinación de

Tengo dos tablas de mysql – una tabla de ventas:

+----------------+------------------------------+------+-----+---------+-------+
| 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    |       |
+----------------+------------------------------+------+-----+---------+-------+

y una tabla de elementos:

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

La tabla de ventas contiene varios registros para cada ItemID – uno para cada SaleWeek. Quiero seleccionar todos los artículos vendidos por unir las dos tablas como:

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

Sin embargo, esta es la devolución de varios ItemId valores basados en las múltiples entradas para cada SaleWeek. Puedo hacer una clara seleccione para devolver sólo una ItemID – no quiero tener a una consulta de la última SaleWeek debido a que algunos de los artículos pueden no tener una entrada para la última SaleWeek así que tengo que conseguir la última venta. Qué necesito para especificar DISTINTOS o utilizar un LEFT OUTER JOIN o algo?

¿Has probado DISTINTAS? Es posible que el tornillo de seguridad de su pedido, dependiendo de qué DBMS se utiliza…

OriginalEl autor George | 2010-01-15

4 respuestas

  1. 18

    Un DISTINCT debe hacer lo que estás buscando:

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

    Que volvería sólo distintos items.ItemName, items.ItemId tuplas.

    OriginalEl autor Kaleb Brasee

  2. 8

    Que había un comentario sobre las ventas de la semana también. Y querer que el más reciente de la semana, puede que desee probar el uso de un GRUPO de

    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

    Puede que tenga que cambiar el ORDEN en el ordinal 3 ° columna de referencia si así lo desea en función de la columna.. Esta consulta le dará a cada elemento diferenciado Y la más reciente de la semana en que se vendió.

    OriginalEl autor DRapp

  3. 1

    Podemos usar este:

    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`

    OriginalEl autor sivaprakash

  4. 0
        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)

    OriginalEl autor Suresh Kumar Amrani

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *