1

表(合同)中有一个称为服务位置的列。我必须显示服务位置与表中任何其他行匹配的所有行。

    Table Example

 A    B    C
 1    2    3
 3    2    1
 2    5    3

我需要一个查询,其中将根据第二列的比较返回第一行和第二行。我假设我需要使用 HAVING COUNT( B) > 1

我想出了这个

SELECT  `contract_number` 
FROM  `contracts` 
WHERE  `import_id` =  'fe508764-54a9-41f7-b36e-50ebfd95971b'
GROUP BY  `service_location_id` 
HAVING COUNT(`service_location_id` ) >1  

但它不会产生我真正需要的东西。

4

2 回答 2

2

Having会这样做,但你需要像这样使用它

SELECT  *
FROM    Contracts
        INNER JOIN
        (   SELECT  B
            FROM    Contracts
            GROUP BY B
            HAVING COUNT(*) > 1 -- MORE THAN ONE ROW WITH THE SAME VALUE
        ) dupe
            ON dupe.B = Contracts.B

但是,根据您的索引,您可能会发现自联接性能更好:

SELECT  DISTINCT t1.*
FROM    contracts t1
        INNER JOIN contract` t2
            ON t1.B = t2.B
            AND t1.A <> t2.A
于 2012-09-18T15:37:40.203 回答
1

选择 * 从 sheet1 哪里 C

Csheet1 GROUP BY C HAVING COUNT( ) >1 ) ORDER CBY C LIMIT 0 , 5000 中选择

于 2013-05-31T08:29:07.263 回答