没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:李爽夏|2019-02-15 09:39:52.000|阅读 828 次
概述:本篇文章介绍了如何从MySQL中的多个表和视图中获取行计数。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
Navicat Premium是一个可连接多种数据库的管理工具,它可以让你以单一程序同时连接到MySQL、Oracle及PostgreSQL数据库,让管理不同类型的数据库更加的方便。
在上篇文章获取MySQL中的高级行数(第2部分)中,我们使用了原生COUNT() 函数来计算唯一值以及满足条件的值。在今天的最后第三部分中,我们将学习如何从数据库或整个模式中的所有表中获取行计数。
您不必对每个表运行计数查询来获取行数。如果您计划多次运行外部脚本,那么这将是一件乏味的事情,并且可能需要外部脚本。
INFORMATION_SCHEMA数据库是每个MySQL实例存储有关MySQL服务器维护的所有其他数据库的信息的地方。有时也称为数据字典和系统目录,它是查找有关数据库、表、列的数据类型或访问权限的信息的理想位置。
INFORMATION_SCHEMA “TABLES”表提供有关数据库中其他表的信息。通过查询它,您可以通过一个查询获得精确的行数。
很容易获得一个数据库的行数。只需添加一个条件是table_schema列与数据库名称匹配的WHERE子句:
SELECT TABLE_NAME, TABLE_ROWS FROM `information_schema`.`tables` WHERE `table_schema` = 'YOUR_DB_NAME'; +------------+------------+ | TABLE_NAME | TABLE_ROWS | +------------+------------+ | Table1 | 105 | +------------+------------+ | Table2 | 10299 | +------------+------------+ | Table3 | 0 | +------------+------------+ | Table4 | 1045 | +------------+------------+
为模式中的所有数据库获取行计数需要付出更多的努力。为此,我们必须使用一份准备好的声明。
在语句中,group_concat()函数将多行打包为一个字符串,以便将表名列表转换为由联合连接的多个计数的字符串。
Select -- Sort the tables by count concat( 'select * from (', -- Aggregate rows into a single string connected by unions group_concat( -- Build a "select count(1) from db.tablename" per table concat('select ', quote(db), ' db, ', quote(tablename), ' tablename, ' 'count(1) "rowcount" ', 'from ', db, '.', tablename) separator ' union ') , ') t order by 3 desc') into @sql from ( select table_schema db, table_name tablename from information_schema.tables where table_schema not in ('performance_schema', 'mysql', 'information_schema') ) t;
我们连接的select语句保存在@sql变量中,这样我们就可以将其作为准备好的语句运行:
-- Execute @sql prepare s from @sql; execute s; deallocate prepare s; +-----+-----------+------------+ | db | tablename | rowcount | +-----+-----------+------------+ | DB1 | Table1 | 1457 | +-----+-----------+------------+ | DB1 | Table2 | 1029 | +-----+-----------+------------+ | DB2 | Table1 | 22002 | +-----+-----------+------------+ | DB2 | Table2 | 1022 | +-----+-----------+------------+
这些查询将执行得非常快,并在MyISAM表上产生非常精确的结果。但是,事务性存储引擎(如InnoDB)不保留表中的内部行数。相反,事务性存储引擎对表中的一些随机页进行采样,然后估计整个表的总行数。MVCC(一种允许并发访问行的特性)的后果是,在任何一个时间点,一行都有多个版本。因此,count(1)将取决于事务启动的时间及其隔离级别。在InnoDB这样的事务性存储引擎上,您可以期望计数精确到实际行数的4%以内。
购买Navicat Premium正版授权,请点击“”哟!
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@wqylolg.cn
在处理 HTML 表中呈现的结构化数据时,将 HTML 转换为 Excel 是一种常见需求。使用 Aspose.Cells,我们可以轻松地将 HTML 文件转换为不同编程语言的 Excel。
在本文中,我们将探讨 Stimulsoft 与WinUI项目的集成。
无论您是要编译演示文稿的图像、创建作品集还是简单地整理照片,将 JPG 文件合并为单个 PDF 都非常有用。通过本文,您将学习如何使用 Aspose.PDF 将 JPG 合并为 PDF,并提供分步说明和代码示例。
ONLYOFFICE 宏功能强大且用途广泛,不仅可用于自动执行文档、电子表格和演示文稿中的任务,还可用于 PDF 表单中的任务。在这篇博文中,我们将向您展示如何创建和运行一个独特的宏,该宏对表单中的特定字段执行计算。
Navicat Premium 是一套数据库管理工具,让你使用一个程序即可同時连接到 MySQL、MariaDB、SQL Server、SQLite、Oracle 和 PostgreSQL 数据库。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@wqylolg.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢