質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

解決済

1回答

1174閲覧

以前した質問の棚卸中

imamoto_browser

総合スコア1161

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

0クリップ

投稿2017/05/29 11:26

編集2017/05/29 11:29

以前下記のような質問をいたしました。

union句をサブクエリに含むクエリはどんな場合に使われますか?また、union句が使えない場合とはどんなときですか。例などを交えて説明いただけると幸いです。

回答として下記のような内容をいただきました。

テストデータを作る場合

sql

1insert into tbl 2(col1, col2, col3) 3select * 4from( 5 select 'hoge1' col1, 'hoge2' col2, 'hoge3' col3 6 union all 7 select 'huga1' col1, 'huga2' col2, 'huga3' col3 8) as hoge;

上記のようにinsertするメリットがよくわからないのですが、なぜ副問い合わせとして上記のような記述スタイルをとるのでしょうか。

個人的にはFWのシーダーを使ったり、使わなくともinsert intoで普通にテストデータをinsertした方がシンプルでわかりよいと思うのですが。上記のようにunion allと派生テーブルを使ってinsertするメリットはなんでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

UNION ALLを使う限り、重複データの除外がないので

SQL

1insert into tbl 2select * from( 3select 'hoge1','hoge2','hoge3' 4union all 5select 'huga1','huga2','huga3' 6) as hoge;

としても

SQL

1insert into tbl select 'hoge1','hoge2','hoge3'; 2insert into tbl select 'huga1','huga2','huga3';

としても、結果は同じです
(今回のデータは重複もしていないのでUNIONでも一緒ですが・・)
違うところと言えばinsertをするセッションが前者は1回で済むのに対して
後者は2回発生していること
insert構文を複数回実行するとオーバーヘッドが大きいので
2件程度ではさほど意味はありませんが、数が多くなればそれなりの
処理速度の差が出ると思います。

それもあってMySQLの場合、テストデータはバルクinsertを利用して
投入することが多いでしょう

SQL

1insert into tbl values('hoge1','hoge2','hoge3'), 2('huga1','huga2','huga3');

投稿2017/05/30 01:39

yambejp

総合スコア114769

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問