我需要获取具有最大行数的表的名称,我可以找到具有函数计数的最大行数而不是函数max,但我不知道如何查看哪个表是最大的,有人可以帮忙吗?
答案 0 :(得分:1)
尝试此查询:
SELECT table_name, table_rows
FROM information_schema.TABLES
ORDER table_rows;
表示所有信息,这是最大的信息:
SELECT table_name, table_rows
FROM information_schema.TABLES WHERE table_rows =
(SELECT MAX(table_rows) FROM information_schema.TABLES);
PHP:
$result = mysql_query("SELECT table_name, table_rows
FROM information_schema.TABLES WHERE table_rows =
(SELECT MAX(table_rows) FROM information_schema.TABLES)");
if (!$result) {
echo "error"
}
while ($row = mysql_fetch_assoc($result)) {
echo $row['table_name'];
echo $row['table_rows'];
}
答案 1 :(得分:0)
show table status
将为您提供所需的信息。
答案 2 :(得分:0)
$sql = "SHOW TABLES FROM $dbname";
$result = $mysqli->query($sql);
if (!$result) {
echo "DB Error, could not list tables\n";
echo 'MySQL Error: ' . mysql_error();
exit;
}
while ($row = mysql_fetch_row($result)) {
$count = "select count(*) as cnt from : {$row[0]}\n";
$result = $mysqli->query($count);
$row_array=$result->fetch_array(MYSQLI_ASSOC);
$print[$row[0]] = $row_array['cnt'];
}
asort($print);
$ print将使用key作为表名保存所有行的值。 使用asort(),您可以按照订单排序。
答案 3 :(得分:0)
要直接从任何数据库获取,请运行此查询
select TABLE_NAME
FROM information_schema.TABLES
where TABLE_ROWS = (SELECT max(TABLE_ROWS) from information_schema.TABLES);
如果你想在php中运行它,你不能只回显你刚刚运行的查询 这就是你得到Resource#10错误的原因。检查this question
对此的解决方案是使用“mysql_fetch_assoc”,如Mikhail的答案,它实际上为您提供了正确的结果:“time_zone_transition117210”
由于您不明白这是您的答案,因此您似乎希望将查询限制为某个架构。 所以你在php中的完整答案如下
$result = mysql_query(
"SELECT table_name, table_rows
FROM information_schema.TABLES
WHERE table_rows = (
SELECT MAX(table_rows) FROM information_schema.TABLES
WHERE TABLE_SCHEMA ='YOUR_SCHEMA_NAME'
)
AND TABLE_SCHEMA = 'YOUR_SCHEMA_NAME'"
);
while ($row = mysql_fetch_assoc($result)) {
echo 'table name is: '. $row['table_name'] .' \n ';
echo 'number of rows is: '. $row['table_rows'] .' \n ';
}
不要忘记在内部和外部查询中将YOUR_SCHEMA_NAME替换为实际名称。