根据列值从 mysql 结果中过滤重复项

发布于 2024-12-06 22:40:06 字数 1169 浏览 1 评论 0原文

我在解决如何从以下 mysql 表返回所需行时遇到一些问题:

first_name      last_name      collection
==========================================
   Bob            Jones            1
   Ted            Jones            1
   Bob            Jones            1
   Bob            Jones            2
   Ted            Baker            2

我想根据列“first_name”和“last_name”返回名称计数。通常,这只是使用“按名字、姓氏分组”的简单情况,因此我们将得到以下结果:鲍勃·琼斯 (Bob Jones) 计数为 3,泰德·琼斯 (Ted Jones) 计数为 1,泰德·贝克 (Ted Baker) 计数为 1。

不过,难点在于第三栏“收藏”。我需要排除集合之间的重复名称,但不需要排除集合内的重复名称。因此,我们将在第一个集合的计数中包含所有名称,但仅在第二个集合的计数中包含名称(如果这些名称未出现在第一个集合中)。

因此,期望的结果如下:Bob Jones 计数为 2,Ted Jones 计数为 1,Ted Baker 计数为 1。

first_name      last_name      collection             included?
==========================================         ===============
   Bob            Jones            1                    Yes
   Ted            Jones            1                    Yes
   Bob            Jones            1                    Yes
   Bob            Jones            2                    No
   Ted            Baker            2                    Yes

我确实尝试过解决这个问题,但我开始没有想法了。任何帮助将不胜感激...谢谢!

I'm having some problems working out how to return the desired rows from the following mysql table:

first_name      last_name      collection
==========================================
   Bob            Jones            1
   Ted            Jones            1
   Bob            Jones            1
   Bob            Jones            2
   Ted            Baker            2

I want to return the count of names based on columns 'first_name' and 'last_name'. Ordinarily it would just be a simple case of using 'group by first_name, last_name', so we would have the following result: a count of 3 for Bob Jones, 1 for Ted Jones, and 1 for Ted Baker.

However, the difficulty is the third column 'collection'. I need to exclude duplicate names between collections, but not within collections. So we'd include all names in the count for the first collection, but only include names in the count from the second collection if they do NOT occur in the first collection.

So, the desired result would be as follows: a count of 2 for Bob Jones, 1 for Ted Jones, and 1 for Ted Baker.

first_name      last_name      collection             included?
==========================================         ===============
   Bob            Jones            1                    Yes
   Ted            Jones            1                    Yes
   Bob            Jones            1                    Yes
   Bob            Jones            2                    No
   Ted            Baker            2                    Yes

I have really tried to get my head around this but I am starting to run out of ideas. Any help would be hugely appreciated... thanks!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

你是暖光i 2024-12-13 22:40:06

也许

SELECT first_name, last_name, COUNT( DISTINCT collection) AS cnt
FROM yourtable
GROUP BY first_name, last_name

COUNT DISTINCT 会消除重复的 Bob/Jones/1 记录。

Perhaps

SELECT first_name, last_name, COUNT( DISTINCT collection) AS cnt
FROM yourtable
GROUP BY first_name, last_name

The COUNT DISTINCT would eliminate the duplicate Bob/Jones/1 records.

蓦然回首 2024-12-13 22:40:06

这是你所期待的吗?

SELECT u1.first_name, u1.last_name, u1.collection FROM users u1 
WHERE u1.collection = (SELECT min(u2.collection) 
    FROM users u2 WHERE u1.first_name = u2.first_name
    AND u1.last_name = u2.last_name);

http://www.sqlfiddle.com/#!2/bd086/7

Is this what you are expecting?

SELECT u1.first_name, u1.last_name, u1.collection FROM users u1 
WHERE u1.collection = (SELECT min(u2.collection) 
    FROM users u2 WHERE u1.first_name = u2.first_name
    AND u1.last_name = u2.last_name);

http://www.sqlfiddle.com/#!2/bd086/7

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文