In MySQL wird das Abrufen einer Liste von Tabellennamen innerhalb einer Datenbank normalerweise mit dem Befehl SHOW TABLES erreicht. Diese Methode eignet sich jedoch nicht zum Füllen einer anderen Tabelle mit diesen Namen mithilfe einer direkten INSERT INTO-Abfrage.
Um dieses Ziel zu erreichen, kann eine standardmäßige SELECT-Anweisung verwendet werden, die jedoch den Zugriff auf die entsprechende Tabelle innerhalb von MySQL erfordert Systemdatenbank. Diese Tabelle ist die Tabelle „information_schema.tables“, die Informationen zu allen Tabellen auf dem verbundenen Server enthält.
So erhalten Sie die Namen aller Tabellen auf dem MySQL-Server:
SELECT table_name FROM information_schema.tables;
Um die Namen von Tabellen aus einer bestimmten Datenbank abzurufen:
SELECT table_name FROM information_schema.tables WHERE table_schema = 'your_database_name';
So fügen Sie die ein Tabellennamen in eine andere Tabelle:
INSERT INTO metadata(table_name) SELECT table_name FROM information_schema.tables WHERE table_schema = 'your_database_name';
Die Verwendung der Tabelle information_schema.tables ermöglicht das Abrufen von Tabellennamen mithilfe einer regulären SELECT-Anweisung und löst so das Problem des direkten Einfügens von Tabellennamen, die mit dem Befehl SHOW TABLES erhalten wurden .
Weitere Informationen und ausführliche Erklärungen finden Sie in der MySQL-Dokumentation unter: http://dev.mysql.com/doc/refman/5.0/en/information-schema.html
Das obige ist der detaillierte Inhalt vonWie kann ich MySQL-Tabellennamen mithilfe von SELECT-Anweisungen abrufen und einfügen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!