ホームページ >データベース >mysql チュートリアル >MySQL テーブル内のすべての列を連結するにはどうすればよいですか?
MySQL のすべての列の連結
MySQL では、* ワイルドカード キーワードを CONCAT() 関数で使用して、すべての列を連結することはできません。テーブル。代わりに、各列名を明示的にリストする必要があります:
<code class="sql">SELECT CONCAT(col1, col2, col3, ...) FROM yourtable;</code>
または、CONCAT_WS() 関数を使用して null 値をスキップできます:
<code class="sql">SELECT CONCAT_WS(',', col1, col2, col3, ...) FROM yourtable;</code>
必要に応じて、動的クエリを利用して列名を手動で指定します。テーブルの列名を取得します:
<code class="sql">SELECT `column_name` FROM `information_schema`.`columns` WHERE `table_schema` = DATABASE() AND `table_name` = 'yourtable';</code>
GROUP_CONCAT を使用して列名のカンマ区切りリストを取得します:
<code class="sql">GROUP_CONCAT(CONCAT('`', column_name, '`'))</code>
次に、要素を連結して動的クエリを作成します:
<code class="sql">SELECT CONCAT( 'SELECT CONCAT_WS(\'\',', GROUP_CONCAT(CONCAT('`', column_name, '`') ORDER BY column_name), ') AS all_columns FROM yourtable;') FROM `information_schema`.`columns` WHERE `table_schema` = DATABASE() AND `table_name` = 'yourtable' INTO @sql;</code>
このクエリは、@sql 変数を次のような文字列に設定します:
<code class="sql">SELECT CONCAT_WS('', col1, col2, col3, ...) AS all_columns FROM yourtable;</code>
最後に、次の動的クエリを実行します:
<code class="sql">PREPARE stmt FROM @sql; EXECUTE stmt;</code>
例SQLfiddle を使用して、提供された HTML ソースを参照してください。
以上がMySQL テーブル内のすべての列を連結するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。