sql >> Databasteknik >  >> RDS >> Mysql

Visa alla tabeller i en MySQL-databas med PHP?

Hur får man tabeller

1. SHOW TABLES

mysql> USE test;
Database changed
mysql> SHOW TABLES;
+----------------+
| Tables_in_test |
+----------------+
| t1             |
| t2             |
| t3             |
+----------------+
3 rows in set (0.00 sec)

2. SHOW TABLES IN db_name

mysql> SHOW TABLES IN another_db;
+----------------------+
| Tables_in_another_db |
+----------------------+
| t3                   |
| t4                   |
| t5                   |
+----------------------+
3 rows in set (0.00 sec)

3. Använda informationsschema

mysql> SELECT TABLE_NAME
       FROM information_schema.TABLES
       WHERE TABLE_SCHEMA = 'another_db';
+------------+
| TABLE_NAME |
+------------+
| t3         |
| t4         |
| t5         |
+------------+
3 rows in set (0.02 sec)

till OP

du har bara hämtat 1 rad. fixa så här:

while ( $tables = $result->fetch_array())
{
    echo $tmp[0]."<br>";
}

och jag tror att information_schema skulle vara bättre än SHOW TABLES

SELECT TABLE_NAME
FROM information_schema.TABLES 
WHERE TABLE_SCHEMA = 'your database name'

while ( $tables = $result->fetch_assoc())
{
    echo $tables['TABLE_NAME']."<br>";
}


  1. Kan inte trunkera tabellen eftersom den refereras av en FOREIGN KEY-begränsning?

  2. Så skapar du ett tomt formulär i Access 2016

  3. hur man hittar och ersätter ett ord i en mysql-kolumn?

  4. MySQL användarhantering