比较2个数据集时查找唯一值

时间:2013-10-05 14:54:48

标签: mysql

我有下表,名为versiontrim,带有一些示例数据:

version_id   trim_id
    410        3
    410        5
    410        10
    410        15
    410        20
    411        2
    411        5
    411        15
    411        25
    411        28

另一个表修剪,保存每个trim_id的细节,如下所示:

 trim_id    trim 
    2       Air conditioner auto            
    3       Air conditioner manual
    5       Airbag
    10      Cloth seats
    25      Leather seats
    etc.....

我希望为每个SET OF 2 version_id提取唯一的trim_id。结果应如下所示:

version_id trim_id  trim                   version_id  trim_id     trim
                                           411         2           Air conditioner auto
410        3        Air conditioner manual
410        10       Cloth seats
                                           411         25        Leather seats
410        20       blahblah
                                           411         28         blah....
etc...

我确实设法使用下面的查询单独获取每个集合,交换version_id:

SELECT version_id, trim_id, trim
FROM versiontrim a
INNER JOIN trims USING(trim_id)
WHERE a.version_id = 411
AND NOT EXISTS
(
 SELECT * FROM versiontrim b 
 INNER JOIN trims USING(trim_id)
 WHERE a.trim_id = b.trim_id
 AND b.version_id = 410
)

我确信有一种更简单的方法可以做到这一点,只需一个查询,这样我就可以正确输出它。 谢谢你的帮助。

2 个答案:

答案 0 :(得分:1)

SELECT 
  CASE 
    WHEN v.version_id = 410 THEN v.version_id
    ELSE ''
  END  AS Left_Version
  ,CASE 
    WHEN v.version_id = 410 THEN v.trim_id
    ELSE ''
  END  AS Left_Trim_id
  ,CASE 
    WHEN v.version_id = 410 THEN t.trim
    ELSE ''
  END  AS Left_Trim
  ,CASE 
    WHEN v.version_id = 411 THEN v.version_id
    ELSE ''
  END  AS Right_Version
  ,CASE 
    WHEN v.version_id = 411 THEN v.trim_id
    ELSE ''
  END  AS Right_Trim_id
  ,CASE 
    WHEN v.version_id = 411 THEN t.trim
    ELSE ''
  END  AS Right_Trim
FROM(SELECT trim_id, COUNT(*)
     FROM versiontrim
     WHERE version_id IN (410,411)
     GROUP BY trim_id
     HAVING COUNT(*) = 1) AS vt
JOIN versiontrim AS v
 ON v.trim_id = vt.trim_id
   AND v.version_id IN (410,411)
JOIN trims AS t
 ON v.trim_id = t.trim_id
GROUP BY v.trim_id
ORDER BY v.trim_id;

答案 1 :(得分:0)

试试这个::

Select 
 version_id, trim_id, trim
FROM versiontrim a
INNER JOIN trims t on (a.trim_id=t.trim_id)
GROUP BY a.version_id, t.trim_id