Heim > Datenbank > MySQL-Tutorial > Wie führe ich SQL-Abfragen mit dynamischen Tabellennamen in MySQL aus?

Wie führe ich SQL-Abfragen mit dynamischen Tabellennamen in MySQL aus?

Patricia Arquette
Freigeben: 2024-11-09 10:56:02
Original
448 Leute haben es durchsucht

How to Execute SQL Queries with Dynamic Table Names in MySQL?

Dynamische Tabellennamen in SQL-Anweisungen

Das Ausführen von SQL-Abfragen mit dynamischen Tabellennamen kann eine Herausforderung sein. Betrachten Sie das folgende Beispiel:

SET @id := '47';
SET @table := @id+'_2013_2014_voucher';
SELECT * FROM @table;
Delete FROM @table where>
Nach dem Login kopieren

Diese Abfrage löst den folgenden Fehler aus:

[Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '@table' at line 1
Nach dem Login kopieren

Lösung mit vorbereiteten Anweisungen

Der empfohlene Ansatz für Der Umgang mit dynamischen Tabellennamen besteht darin, vorbereitete Anweisungen zu verwenden. Mit vorbereiteten Anweisungen können Sie den Tabellennamen dynamisch angeben und gleichzeitig die richtige Syntax und Sicherheit gewährleisten. In MySQL können Sie die Anweisungen PREPARE und EXECUTE wie folgt verwenden:

SET @id := '47';
SET @table := concat(@id,'_2013_2014_voucher');
set @qry1:= concat('select * from ',@table);
prepare stmt from @qry1 ;
execute stmt ;
Nach dem Login kopieren

Die Funktion CONCAT() wird verwendet, um die Tabellennamenzeichenfolge dynamisch zu verketten. Die vorbereitete Anweisung wird dann ausgeführt, wodurch der Syntaxfehler vermieden wird.

Anwenden auf Löschabfragen

Derselbe Ansatz kann auf Löschabfragen erweitert werden:

SET @qry2:= concat('DELETE FROM ',@table,' where>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie führe ich SQL-Abfragen mit dynamischen Tabellennamen in MySQL aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage