ホームページ > データベース > mysql チュートリアル > MySQL テーブル内のすべての列を連結するにはどうすればよいですか?

MySQL テーブル内のすべての列を連結するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-10-24 17:29:02
オリジナル
1069 人が閲覧しました

How to Concatenate All Columns in a MySQL Table?

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 サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート