当前位置: 首页 > news >正文

mysql中用一个查询获取多个数据库(模式)和表的计数之和

问题

下面的查询返回了4排数据,这很好。但我同时需要对同一个查询中的所有计数求和。这如何实现?我已经尝试了多种不同的方法,但只得到sintax报错。

SELECT COUNT(*) FROM `schema1`.`table` WHERE STATE = 17 AND LEVEL = 1
UNION ALL
SELECT COUNT(*) FROM `schema2`.`table` WHERE STATE = 17 AND LEVEL = 1
UNION ALL
SELECT COUNT(*) FROM `schema3`.`table` WHERE STATE = 17 AND LEVEL = 1
UNION ALL
SELECT COUNT(*) FROM `schema4`.`table` WHERE STATE = 17 AND LEVEL = 1

回答

  1. 只需要输入更少的代码:
SELECT s1, s2, s3, s4,s1 + s2 + s3 + s4 AS totalFROM ( SELECT( SELECT COUNT(*) FROM `schema1`.`table` WHERE STATE = 17 AND LEVEL = 1 ) AS s1,( SELECT COUNT(*) FROM `schema2`.`table` WHERE STATE = 17 AND LEVEL = 1 ) AS s2,( SELECT COUNT(*) FROM `schema3`.`table` WHERE STATE = 17 AND LEVEL = 1 ) AS s3,( SELECT COUNT(*) FROM `schema4`.`table` WHERE STATE = 17 AND LEVEL = 1 ) AS s4) AS counts;

如果有性能问题,确保每个表都设置了INDEX(state, level)。(在这种情况下,索引中列的顺序并不重要。)

如果这只是许多困难的查询方法中的一个,您可能需要重新考虑给数据配备多个数据库(模式)。

  1. 将你的子查询组合起来,并在它们上面放个SELECT子句
SELECT
(SELECT COUNT(*) AS cnt FROM `schema1`.`table` WHERE STATE = 17 AND LEVEL = 1) s1
,
(SELECT COUNT(*) AS cnt FROM `schema2`.`table` WHERE STATE = 17 AND LEVEL = 1) s2
,
(SELECT COUNT(*) AS cnt FROM `schema3`.`table` WHERE STATE = 17 AND LEVEL = 1) s3
,
(SELECT COUNT(*) AS cnt FROM `schema4`.`table` WHERE STATE = 17 AND LEVEL = 1) s4

这应该会给你输出一个单行四列的结果。

如果你需要在一个查询中对他们进行求和,请使用下面这个查询。

你可以把它们放进一个select子句中,让它给你求和。这是一个例子。

SELECT SUM(cnt) FROM
(
SELECT COUNT(*) AS cnt FROM `schema1`.`table` WHERE STATE = 17 AND LEVEL = 1
UNION ALL
SELECT COUNT(*) AS cnt FROM `schema2`.`table` WHERE STATE = 17 AND LEVEL = 1
UNION ALL
SELECT COUNT(*) AS cnt FROM `schema3`.`table` WHERE STATE = 17 AND LEVEL = 1
UNION ALL
SELECT COUNT(*) AS cnt FROM `schema4`.`table` WHERE STATE = 17 AND LEVEL = 1
) tmp

欢迎来弦圈一起翻译StackOverflow等国外编程内容👇👇👇

翻译原文:mysql中用一个查询获取多个数据库(模式)和表的计数之和
更多数据库相关翻译内容:数据库 - 弦圈
更多其他趣味内容:弦圈 - 找到属于你的圈子

http://www.lryc.cn/news/427732.html

相关文章:

  • linux patch 的制作方式
  • 白骑士的C#教学进阶篇 2.4 LINQ查询
  • 2024华为OD机试真题- 贪吃的猴子Python-C卷D卷-200分
  • 4-1-2 直流电机(电机专项教程)
  • [图解]用例规约之扩展路径
  • 学习记录第二十八天
  • SpringBoot的事务/调度/缓存/邮件发送和一些Spring知识点总结
  • 透明加密技术
  • 深入理解Faiss:高效向量检索的利器
  • RK3576 芯片介绍
  • Python模块篇(五)
  • 西安旅游系统--论文pf
  • 分享一个思路,使用插桩技术解决慢查询测试问题
  • 【STM32项目】在FreeRtos背景下的实战项目的实现过程(二)
  • javaer快速入门 goweb框架 gin
  • SQL - 数据类型
  • 进程相关知识
  • 萝卜快跑和端到端的自动驾驶(1)
  • 通信原理学习笔记
  • 系统编程---day4
  • 01:电容的什么,各类电容的优缺点
  • Android+Jacoco+code-diff全量、增量覆盖率生成实战
  • 乌龟对对碰在线版
  • 如何更改select option边框颜色和选中的颜色
  • 6. 数据结构—串的匹配算法
  • 九大服务架构性能优化方式
  • 【RabbitMQ】 相关概念 + 工作模式
  • 嵌入式学习 ——(Linux高级编程——进程)
  • C++练习备忘录
  • 改善工作流