Ответы:
SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = 'dbName';
Это мое:
USE databasename;
SHOW TABLES;
SELECT FOUND_ROWS();
AND table_type = 'BASE TABLE'
use databasename;
команде. Если база данных действительно большая, команда может выполняться с длительным временем ожидания. В этом случае вход в систему должен быть выполнен с опцией -A, то есть:, mysql -uroot -p -A
и команда будет работать быстро.
Если вы хотите подсчитать все базы данных плюс сводку, попробуйте следующее:
SELECT IFNULL(table_schema,'Total') "Database",TableCount
FROM (SELECT COUNT(1) TableCount,table_schema
FROM information_schema.tables
WHERE table_schema NOT IN ('information_schema','mysql')
GROUP BY table_schema WITH ROLLUP) A;
Вот пример выполнения:
mysql> SELECT IFNULL(table_schema,'Total') "Database",TableCount
-> FROM (SELECT COUNT(1) TableCount,table_schema
-> FROM information_schema.tables
-> WHERE table_schema NOT IN ('information_schema','mysql')
-> GROUP BY table_schema WITH ROLLUP) A;
+--------------------+------------+
| Database | TableCount |
+--------------------+------------+
| performance_schema | 17 |
| Total | 17 |
+--------------------+------------+
2 rows in set (0.29 sec)
Попробуйте !!!
FROM
предложении используется подзапрос ? Почему не просто так SELECT IFNULL(table_schema, 'Total') Database, COUNT(*) TableCount FROM information_schema.tables WHERE table_schema NOT IN ('information_schema','mysql') GROUP BY table_schema WITH ROLLUP
?
SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = 'dbo' and TABLE_TYPE='BASE TABLE'
Это даст вам имена и количество таблиц всех баз данных в вашем mysql
SELECT TABLE_SCHEMA,COUNT(*) FROM information_schema.tables group by TABLE_SCHEMA;
Чтобы подсчитать количество столов, просто сделайте это:
USE your_db_name; -- set database
SHOW TABLES; -- tables lists
SELECT FOUND_ROWS(); -- number of tables
Иногда легкие вещи сделают работу.
SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = 'database_name';
из командной строки:
mysql -uroot -proot -e "select count(*) from
information_schema.tables where table_schema = 'database_name';"
в приведенном выше примере root - это имя пользователя и пароль, размещенные на localhost.
Надеюсь, это поможет и вернет только количество таблиц в базе данных.
Use database;
SELECT COUNT(*) FROM sys.tables;
sys.tables
не существует вmysql
FOUND_ROWS()
было больше, чем количество таблиц, которые вернулись, когда я использовал первый метод.