0

我有这样的查询,它很好地向我展示了哪个 product.model 被复制:

SELECT product.model, product_description.name, COUNT( * ) AS Count
FROM product, product_description
WHERE product.product_id = product_description.product_id
GROUP BY product.model ORDER BY COUNT
HAVING Count >1

但是我不能强制此查询为每个重复的 product.model 显示 product_description.name 的内容,以比较 product_description.name

我试图在这个结果上输入,但我得到的只是'#1241 - 操作数应该包含 1 列'。知道如何进一步处理此结果吗?

4

2 回答 2

0

您将需要一个子查询来执行此操作:

select 
    p.model, pd.name
from 
    product as p, product_description as pd
where 
    p.product_id = pd.product_id
    and p.model in (
        select p.model 
        from product as p, product_description as pd 
        where p.product_id = pd.product_id 
        group by p.model having count(p.name)>1)

希望这可以帮助

于 2013-04-17T23:56:43.980 回答
0

根据您想要的结果,如果您想查看哪些型号在产品表中有多个记录,然后想查看关联的产品描述,您可以使用GROUP_CONCAT组合您的描述。

SELECT p.model, group_concat(pd.name), COUNT( 1 ) AS Count
FROM product p
  INNER JOIN product_description pd USING (product_Id)
GROUP BY p.model
HAVING COUNT(1) > 1
ORDER BY 3

SQL 小提琴演示

还有其他方法可以在不同的行中返回,这取决于您的需要。

于 2013-04-18T00:05:53.830 回答