shell 脚本获取MySQL数据库中所有表记录总数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shell 脚本获取MySQL数据库中所有表记录总数相关的知识,希望对你有一定的参考价值。

近期遇到一个需求,mysql数据库中需要统计所有表的记录数据:
查了下资料可以调取information_schema数据表中数据获取所有表记录数据,但是查询出来的数据,发现和手动统计的记录数据不一致,information_schema查询出来的数据部分不准确【原因应该是部分表数据没有自动同步】。折腾了下,于是还是自己手动写个脚本,分享下也做下次备用。
程序结构:
#!/bin/bash

Author:Jerry

tb_name=mysql -u账号 -p密码 -h192.168.x.x -P端口 -e "select table_name from information_schema.tables where table_schema=‘数据库名‘"|awk ‘NR>1{print $1}‘
for name in $tb_name ;
do
tbl_count=mysql -u账号 -p密码 -h192.168.x.x -P端口 -e "select count (*) as times from cwsys.$name;"| tail -1
echo "$name=$tbl_count" >>/home/xxx/xxx.log
done

技术图片
执行脚本:
技术图片
查看生成的统计记录:
技术图片
查看统计数据:
技术图片

以上是关于shell 脚本获取MySQL数据库中所有表记录总数的主要内容,如果未能解决你的问题,请参考以下文章

使用shell脚本快速录入数据

在shell脚本中使用 isql 执行SQL语句 查询sybase数据库中满足条件的记录条数,怎么把查询结果赋给变量?

截断所有 MySql 表的 shell 脚本

获取MySQL中某个数据库下所有表建表语句的DDL

如何使用 shell 脚本检查 MySQL 数据库中是不是存在表?

如何在mysql中定时清除所有库中指定的表中的数据,而不用每个库都写一遍定时任务,求大神指点!!!