Spaltennamen dynamisch für die Abfrageausführung in MySQL verketten
Problemstellung:
In MySQL ist es wünschenswert, Spaltennamen in einer Abfrage zu verketten, wobei der erste Teil des Spaltennamens eine Zeichenfolge und der zweite Teil eine aus einer anderen Abfrage abgerufene Zahl ist.
Lösungsversuch:
Die folgende SQL-Anweisung versucht, die Verkettung zu erreichen:
<code class="sql">SELECT CONCAT('column', mytable.mycolumn) FROM table ...</code>
Dieser Ansatz führt jedoch nicht zum gewünschten Ergebnis und die Verkettung scheint unwirksam zu sein.
Lösung :
Entgegen einer früheren Annahme ist es tatsächlich möglich, Spaltennamen in MySQL mithilfe serverseitig vorbereiteter Anweisungen dynamisch zu erstellen. Betrachten Sie den folgenden Ansatz:
<code class="sql">set @query := ( select concat( "select", group_concat(concat("\n 1 as ", column_name) separator ','), "\nfrom dual") from information_schema.columns where table_name = 'columns') ; prepare s1 from @query ; execute s1 ; deallocate prepare s1 ;</code>
Dieser Code erstellt dynamisch eine Abfragezeichenfolge basierend auf dem Inhalt der Spaltentabelle. Mit der Prepare-Anweisung wird dann der Abfragestring kompiliert, der anschließend mit der Execute-Anweisung ausgeführt werden kann.
Das obige ist der detaillierte Inhalt vonKönnen Spaltennamen für die MySQL-Abfrageausführung dynamisch verkettet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!