mysql数据库实例
简单数据查询操作增删改查是数据表操作的重要组成部分,尤其是数据表的查询更是数据库与各类应用交互的频繁操作之一。本文课主要介绍简单数据查询语句。查询语句基本语法查询语句是实现数据查询的SQL语句,用于实...
2024.11.15前面已经介绍了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;对于非事务性表, table_rows 这个值是精确的,对于事务性引擎,这个值通常是估算的。例如 MyISAM 存储精确的数目。对于其它存储引擎,比如InnoDB本值是一个大约的数,与实际值相差可达40到50%。在这些情况下,使用select COUNT(*) 来获得准确的数目。对于在information_schema数据库中的表,Rows值为NULL。
2、sql拼接统计某个数据库下的所有表的记录数(有点麻烦)可以使用如下的 SQL 语句来批量统计数据库中的表的行数:
select concat( ‘select "‘, TABLE_NAME, ‘", COUNT(*) FROM ‘, TABLE_SCHEMA, ‘.‘, TABLE_NAME, ‘unionALL‘ ) EXEC_SQL FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = ‘fsl_prod‘;把生成的 SQL 语句拷贝出来,并去掉最后的一个“unionALL ”就可以执行了。产生的示例 SQL 如下所示:
select "act_demo_test", COUNT(*) FROM fsl_prod.act_demo_testunionALLSELECT "act_demo_vacation", COUNT(*) FROM fsl_prod.act_demo_vacationunionALLSELECT "act_evt_log", COUNT(*) FROM fsl_prod.act_evt_logunionALLSELECT "act_exception", COUNT(*) FROM fsl_prod.act_exceptionunionALLSELECT "wfl_business_rule_line", COUNT(*) FROM fsl_prod.wfl_business_rule_line;运行结果:
3、存储过程统计某个数据库下的所有表的记录数(多次复用)3.1、创建中间表
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:LOOPfetch sql_cur into sql_str; if no_more_departments = 1 THENleave myLoop;end if;set @v_sql=sql_str;prepare stmt from @v_sql;EXECUTE stmt; /* 将统计结果保存到表中,以便随时都可以查看 */insert INTO table_rowsVALUES ( @v_tab_schema, @v_tab_name, @v_count, sysdate() ); /* 预处理编译 SQL是占用资源的,需使用DEALLOCATE PREPARE释放资源 */DEALLOCATE prepare stmt;end loop myLoop; close sql_cur;END调用存储过程:
call statis_rows(‘mysql‘);call statis_rows(‘fsl_prod‘);查看表行数
select * from table_rows;后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~
简单数据查询操作增删改查是数据表操作的重要组成部分,尤其是数据表的查询更是数据库与各类应用交互的频繁操作之一。本文课主要介绍简单数据查询语句。查询语句基本语法查询语句是实现数据查询的SQL语句,用于实...
2024.11.15如何使用Navicat连接Linux服务器中的mysql数据库是测试人员最基本的工作。有时候项目部署成功了,往往会出现Navicat访问数据库连接失败的问题。为了解决大家在部署环境过程中的一些困扰,...
2024.11.15问题前段时间,开发人员找我咨询一个MySQL数据库的问题,问题大概是这样的,在MySQL数据库里创建一个应用访问用户,可是命令执行一直失败,创建用户的语法没有问题,从mysql.user表里查询,要创...
2024.11.15MySQL查看数据库性能常用命令# 列出MySQL服务器运行各种状态值show global status;# 查询MySQL服务器配置信息语句show variables;# 慢查询show var...
2024.11.12查看所有数据库使用SHOW DATABASES;命令可以列出当前MySQL服务器上的所有数据库:SHOW DATABASES;执行上述命令后,会输出所有的数据库名称列表。进入或选择一个特定的数据库使用...
2024.11.15