在 MySQL 中查找跨多个数据库的表中的总行数?


若要获取跨数据库的表总行数,请使用聚合函数 SUM() 以及 INFORMATION SCHEMA。我们首先创建一个在“web”数据库中的表格 −

mysql> create table DemoTable1568
   -> (
   -> Name varchar(20)
   -> );
Query OK, 0 rows affected (0.61 sec)

使用插入命令在表中插入一些记录 −

mysql> insert into DemoTable1568 values('Chris');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable1568 values('Bob');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable1568 values('David');
Query OK, 1 row affected (0.13 sec)

使用选择语句显示表中的所有记录 −

mysql> select * from DemoTable1568;

这将产生以下输出 −

+-------+
| Name  |
+-------+
| Chris |
| Bob   |
| David |
+-------+
3 rows in set (0.00 sec)

以下是创建“sample”数据库中表的查询 −

mysql> use sample;
Database changed
mysql> create table DemoTable1568
   -> (
   -> Id int
   -> );
Query OK, 0 rows affected (0.99 sec)

使用插入命令在表中插入一些记录 −

mysql> insert into DemoTable1568 values(101);
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable1568 values(102);
Query OK, 1 row affected (0.34 sec)
mysql> insert into DemoTable1568 values(103);
Query OK, 1 row affected (0.29 sec)
mysql> insert into DemoTable1568 values(104);
Query OK, 1 row affected (0.14 sec)

使用选择语句显示表中的所有记录 −

mysql> select * from DemoTable1568;

这将产生以下输出 −

+------+
| Id   |
+------+
|  101 |
|  102 |
|  103 |
|  104 |
+------+
4 rows in set (0.00 sec)

这是查找跨多个数据库的表总行数的查询 −

mysql> select sum(table_rows) as TotalNumberOfRows from information_schema.tables
   -> where table_name='DemoTable1568';

这将产生以下输出 −

+-------------------+
| TotalNumberOfRows |
+-------------------+
|                 7 |
+-------------------+
1 row in set (0.19 sec)

更新于: 2019 年 12 月 13 日

280 浏览

开启你的 职业生涯

完成课程即可获得认证

立即开始
广告