RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1570404
Accepted
mrBars1k
mrBars1k
Asked:2024-03-06 19:51:57 +0000 UTC2024-03-06 19:51:57 +0000 UTC 2024-03-06 19:51:57 +0000 UTC

考虑计数合并 M:M 表中的两个样本

  • 772

共有三个表:艺术、标签和用于标记每件艺术的链接表。

main_tags — 所有标签;

艺术——艺术;

tag_to_art - 标签和艺术之间的连接;

表中部分数据:

SELECT id, ru FROM main_tags ORDER BY id ASC LIMIT 5;

 id |       ru
----+-----------------
  2 | мужчина
  3 | девушка
  4 | длинные волосы
  5 | короткие волосы
  6 | на улице
SELECT id FROM arts;

 id
----
  4
  5
SELECT * FROM tag_to_art;

         tag          | art
----------------------+-----
 девушка              |   5
 девушка              |   4
 длинные волосы       |   5
 на улице             |   4

原来id为4的art有两个标签:女孩和街头,而art 5有女孩和长发。

您可以通过以下方式找到按 id 放置在单独艺术品上的所有标签:

SELECT main_tags.id, tag_to_art.tag
FROM main_tags
JOIN tag_to_art ON main_tags.ru = tag_to_art.tag
WHERE tag_to_art.art = '4';

 id |         tag
----+----------------------
  6 | на улице
  3 | девушка

通过这种方式,您可以了解标签被附加到不同艺术品上的次数:

SELECT COUNT(tag) FROM tag_to_art
WHERE tag = 'девушка';

 count
-------
     2

问题: 如何组合两个查询以获得如下输出:

 id |         tag          | count
----+----------------------+-------
  4 | длинные волосы       |     1
  3 | девушка              |     2

我的尝试:

    art_id = 4 # сюда приходит любой id по запросу

    cur.execute(f"""SELECT main_tags.id, tag_to_art.tag, COUNT(tag_to_art.tag) AS count
                FROM main_tags
                JOIN tag_to_art ON main_tags.ru = tag_to_art.tag
                WHERE tag_to_art.art = '{art_id}'
                GROUP BY main_tags.id, tag_to_art.tag
                ORDER BY count, date DESC
                """)

    data = cur.fetchall()

唉,这样几乎一切都是正确的,但它只计算标签在特定艺术品上使用的次数,而不是在整个表中。

 id |         tag          | count
----+----------------------+-------
  4 | длинные волосы       |     1
  3 | девушка              |     1 # но здесь должно быть 2, оно подсчитало только на одном арте

我需要使用一个查询(可能带有子查询)或 Python 工具来使输出看起来符合要求。

python
  • 1 1 个回答
  • 13 Views

1 个回答

  • Voted
  1. Best Answer
    Akina
    2024-03-06T20:16:49Z2024-03-06T20:16:49Z
    SELECT t1.id, t2.tag, COUNT(*) AS "count"
    FROM main_tags t1
    JOIN tag_to_art t2 ON t1.ru = t2.tag
    JOIN arts t3 ON t2.art = t3.id
    GROUP BY t1.id, t2.tag
    HAVING MAX((t2.art = 4)::INT) = 1;
    
    ID 标签 数数
    6 在街上 1
    3 年轻女子 2
    SELECT t1.id, t2.tag, COUNT(*) AS "count"
    FROM main_tags t1
    JOIN tag_to_art t2 ON t1.ru = t2.tag
    JOIN arts t3 ON t2.art = t3.id
    GROUP BY t1.id, t2.tag
    HAVING MAX((t2.art = 5)::INT) = 1;
    
    ID 标签 数数
    3 年轻女子 2
    4 长发 1

    小提琴

    • 1

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5