详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]

详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]概述前面已经介绍了Oracle如何去获取某用户下的所有表的行数,所以就不介绍了。今天主要分享的是怎么去获取mysql数据库下所有表的数据行数,主

欢迎大家来到IT世界,在知识的湖畔探索吧!

概述

前面已经介绍了Oracle如何去获取某用户下的所有表的行数,所以就不介绍了,今天主要分享的是怎么去获取mysql数据库下所有表的数据行数,主要介绍3个方法。


1、估算某个数据库下的所有表的记录数

可以用MySQL 自带的information_schema.tables 表的统计信息,初步判断表的数据行大小。

select table_schema,table_name,table_type,table_rows from information_schema.tables where table_schema='fsl_prod' order by table_rows desc;

欢迎大家来到IT世界,在知识的湖畔探索吧!

详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]

对于非事务性表, table_rows 这个值是精确的,对于事务性引擎,这个值通常是估算的。例如 MyISAM 存储精确的数目。对于其它存储引擎,比如InnoDB本值是一个大约的数,与实际值相差可达40到50%。在这些情况下,使用SELECT COUNT(*) 来获得准确的数目。对于在information_schema数据库中的表,Rows值为NULL。


2、sql拼接统计某个数据库下的所有表的记录数(有点麻烦)

可以使用如下的 SQL 语句来批量统计数据库中的表的行数:

欢迎大家来到IT世界,在知识的湖畔探索吧!SELECT
 CONCAT( 'SELECT "', TABLE_NAME, '", COUNT(*) FROM ', TABLE_SCHEMA, '.', TABLE_NAME, ' UNION ALL' ) EXEC_SQL 
FROM
 INFORMATION_SCHEMA.TABLES 
WHERE
 TABLE_SCHEMA = 'fsl_prod';
详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]

把生成的 SQL 语句拷贝出来,并去掉最后的一个“ UNION ALL ”就可以执行了。产生的示例 SQL 如下所示:

SELECT "act_demo_test", COUNT(*) FROM fsl_prod.act_demo_test UNION ALL
SELECT "act_demo_vacation", COUNT(*) FROM fsl_prod.act_demo_vacation UNION ALL
SELECT "act_evt_log", COUNT(*) FROM fsl_prod.act_evt_log UNION ALL
SELECT "act_exception", COUNT(*) FROM fsl_prod.act_exception UNION ALL
SELECT "wfl_business_rule_line", COUNT(*) FROM fsl_prod.wfl_business_rule_line;

运行结果:

详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]


3、存储过程统计某个数据库下的所有表的记录数(多次复用)

3.1、创建中间表

欢迎大家来到IT世界,在知识的湖畔探索吧!CREATE TABLE table_rows (DB VARCHAR ( 20 ), TABLE_NAME VARCHAR ( 64 ), count bigint(30), last_update_date datetime ( 0 ) ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '记录数据库所有表的行数' ROW_FORMAT = Dynamic;

3.2、创建

下面的存储过程用到了游标(cursor),循环(loop),动态SQL预处理(prepare)等技术,获得的数据存到table_rows表。

CREATE PROCEDURE statis_rows(in v_schema varchar(50))
BEGIN 
DECLARE sql_str VARCHAR(5000);
declare no_more_departments integer DEFAULT 0;
DECLARE sql_cur CURSOR FOR (
 SELECT
 CONCAT(
 'select ',"'",table_schema,"'",",'",table_name,"',",'count(1)',' into @v_tab_schema,@v_tab_name,@v_count from ',
 TABLE_SCHEMA,
 '.',
 TABLE_NAME,
 ''
 )
 FROM
 information_schema.TABLES
 WHERE table_schema = v_schema
 and table_name <> 'table_rows'
);
DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_more_departments=1;
/* 打开游标,进入循环统计各表的记录 */
OPEN sql_cur;
myLoop:LOOP
fetch sql_cur into sql_str;
 
if no_more_departments = 1 THEN
leave myLoop;
end if;
set @v_sql=sql_str;
prepare stmt from @v_sql;
EXECUTE stmt;
 
/* 将统计结果保存到表中,以便随时都可以查看 */
INSERT INTO table_rows
VALUES
 (
 @v_tab_schema,
 @v_tab_name,
 @v_count,
 sysdate()
 );
 
/* 预处理编译 SQL是占用资源的,需使用DEALLOCATE PREPARE释放资源 */
DEALLOCATE prepare stmt;
end loop myLoop;
 
close sql_cur;
END
详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]

调用存储过程:

call statis_rows('mysql');
call statis_rows('fsl_prod');
详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]

详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]

查看表行数

select * from table_rows;
详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]


后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~

详解mysql数据库三种快速获得某个数据库下的所有表的记录数方法[亲测有效]

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/13787.html

(0)
上一篇 2023年 4月 22日 下午11:58
下一篇 2023年 5月 14日 下午6:00

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信