RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1251544
Accepted
Joshua
Joshua
Asked:2022-03-04 20:21:13 +0000 UTC2022-03-04 20:21:13 +0000 UTC 2022-03-04 20:21:13 +0000 UTC

如何使用链接表中的多个组进行 sql 查询?

  • 772

我们需要获取 table1 中每条记录的 cdr 和 dxf 格式的文件数。并找到有 2 个 cdr 文件和 4 个 dxf 文件的条目。

create table table1
(
   id int, 
   name varchar(255)
);
create table table2
(
   id int,
   table1_id int,
   filename varchar(255),
   filetype varchar(255)
);
insert into table1 (id,name) values
(123, 'name123'),
(124, 'name124'),
(125, 'name125'),
(126, 'name126'),
(127, 'name127'),
(128, 'name128')
insert into table2 (id,table1_id,filename,filetype) values
(1, 123, 'file1', 'cdr'),
(2, 123, 'file1', 'dxf'),
(3, 123, 'file2', 'cdr'),
(4, 123, 'file2', 'dxf'),
(5, 123, 'file3', 'dxf'),
(6, 123, 'file4', 'dxf'),
(7, 124, 'file11', 'cdr'),
(8, 124, 'file11', 'dxf'),
(9, 124, 'file12', 'cdr'),
(10, 124, 'file12', 'dxf')
select * from table1
编号 | 姓名   
--: | :------
123 | 名称123
124 | 名称124
125 | 名称125
126 | 名称126
127 | 名称127
128 | 名称128
select * from table2
编号 | table1_id | 文件名 | 文件类型
-: | --------: | :------- | :--------
 1 | 123 | 文件1 | cdr     
 2 | 123 | 文件1 | dxf     
 3 | 123 | 文件2 | cdr     
 4 | 123 | 文件2 | dxf     
 5 | 123 | 文件3 | dxf     
 6 | 123 | 文件4 | dxf     
 7 | 124 | 文件11 | cdr     
 8 | 124 | 文件11 | dxf     
 9 | 124 | 文件12 | cdr     
10 | 124 | 文件12 | dxf     
-- пример рабочего запроса. но в нем только по типу cdr ищется.

SELECT table1.id, count(table2.filetype) as cdrCount
FROM table1
INNER JOIN table2 ON table1.id = table2.table1_id
WHERE table2.filetype = 'cdr'
GROUP BY table2.table1_id, table2.filetype
HAVING COUNT(table2.filetype) = 2
编号 | cdrCount
--: | --------:
123 | 2
124 | 2
-- ЭТОТ ЗАПРОС НЕ РАБОТАЕТ

-- Ожидаемый результат:
-- ----------------------------
-- | id  | cdrCount | dxfCount |
-- |-----|----------|----------|
-- | 123 |    2     |    4     |  
-- -----------------------------

SELECT table1.id, count(t21.filetype) as cdrCount, count(t22.filetype) as dxfCount
FROM table1
INNER JOIN table2 t21 ON table1.id = t21.table1_id
INNER JOIN table2 t22 ON table1.id = t22.table1_id
WHERE t21.filetype = 'cdr' AND t22.filetype = 'dxf'
GROUP BY t21.table1_id, t21.filetype, t22.table1_id, t22.filetype
HAVING COUNT(t21.filetype) = 2 AND COUNT(t22.filetype) = 4
编号 | cdr计数 | dxfCount
-: | --------: | --------:

db<>在这里摆弄

mysql
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Akina
    2022-03-04T20:25:41Z2022-03-04T20:25:41Z
    SELECT table1.id, 
           SUM(table2.filetype = 'cdr') as cdrCount, 
           SUM(table2.filetype = 'dxf') as dxfCount
    FROM table1
    INNER JOIN table2 ON table1.id = table2.table1_id
    WHERE table2.filetype IN ('cdr', 'dxf')
    GROUP BY table1.id
    HAVING cdrCount = 2 AND dxfCount = 4
    

    https://dbfiddle.uk/?rdbms=mysql_8.0&fiddle=715fbae08974ee0d5308d42bcf2fdcfb

    • 1

相关问题

  • MySQL - 将一列中单元格的每个值与另一列中的值匹配,并将其替换为相邻列中的值

  • 帮助编写 MySQL 查询

  • SELECT 只增加 MYSQL 值

  • 创建 MySQL 表时的字段

  • 如何连接到远程mysql数据库?

  • MySQL单元格中的随机值

Sidebar

Stats

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

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 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