
No.4ベストアンサー
- 回答日時:
出てくる結果が違います。
テーブル1のフィールド1に、
1
2
3
4
5
6
が、
テーブル2のフィールド1に、
1
2
3
7
8
9
が入力されている場合、
SELECT [テーブル1].[フィールド1], [テーブル2].[フィールド1]
FROM テーブル1 LEFT JOIN テーブル2 ON [テーブル1].[フィールド1]=[テーブル2].[フィールド1];
では、結果は、
テーブル1.フィールド1 テーブル2.フィールド1
1 1
2 2
3 3
4 NULL
5 NULL
6 NULL
の6レコードが出力されますが、
SELECT [テーブル1].[フィールド1], [テーブル2].[フィールド1]
FROM テーブル1 INNER JOIN テーブル2 ON [テーブル1].[フィールド1]=[テーブル2].[フィールド1];
では、結果は、
テーブル1.フィールド1 テーブル2.フィールド1
1 1
2 2
3 3
の3レコードしか出力されません。
No.3
- 回答日時:
対応させるべきはinner joinとouter joinなんですけど、
left join は left outer join と同等です。
innter joinは結合する相手のテーブルに対応するデータが
ある場合のみ結果を返しますが、outer joinは相手の
テーブルに対応するデータが無い場合、そのカラムを
NULLとして返します。
あるouter joinのクエリの結果が
(等幅で見れればいいんだけど)
field1 |field2 |
--------+--------+
Apple |Red |
Melon |NULL |
Grape |Purple |
--------+--------+
だとしたら、inner joinは
field1 |field2 |
--------+--------+
Apple |Red |
Grape |Purple |
--------+--------+
のように返します。outer joinは他にright outer joinと
full outer joinがあります。
No.2
- 回答日時:
#1の者です。
先ほどの投稿、以下2点修正します。
>「INNER JOIN」は結合する両方のテーブルにデータがある場合にのみ毛と号の結果データが取得できる、という意味。
→「INNER JOIN」は結合する両方のテーブルにデータがある場合にのみ結合結果データが取得できる、という意味。
>売上伝票番号:00000000001が取得できないのは商品コード:000000003が商品マスタにないからです。
→売上伝票番号:00000000002が取得できないのは商品コード:000000003が商品マスタにないからです。
No.1
- 回答日時:
簡単に言いますと、
「INNER JOIN」は結合する両方のテーブルにデータがある場合にのみ毛と号の結果データが取得できる、という意味。
一方、「LEFT JOIN」は片方にデータがなくても結合結果データが取得できる、という意味です。
例えば、
売上テーブルと商品マスタがあったとします。
データは以下のように入ってます。
売上テーブル
売上伝票番号 商品コード
00000000001 000000001
00000000002 000000003
商品マスタ
商品コード 商品名
000000001 テレビ
000000002 パソコン
このとき、
SELECT 売上伝票番号, 商品名
FROM 売上テーブル
INNER JOIN 商品マスタ
ON 売上テーブル.商品コード = 商品マスタ.商品コード
のSQLでは
売上伝票番号 商品名
00000000001 テレビ
が返ってきます。
売上伝票番号:00000000001が取得できないのは商品コード:000000003が商品マスタにないからです。
次に、
SELECT 売上伝票番号, 商品名
FROM 売上テーブル
LEFT JOIN 商品マスタ
ON 売上テーブル.商品コード = 商品マスタ.商品コード
のSQLでは
売上伝票番号 商品名
00000000001 テレビ
00000000002 [NULL]
が返ってきます。
商品コード:000000003は商品マスタにありませんが、商品名はNULLで売上テーブルのデータは取得されます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- Access(アクセス) アクセス 削除するレコードを含んだテーブルを指定してくださいのエラー対処方法 1 2022/11/24 15:01
- PostgreSQL SQLで検索結果の記事を表示したい 1 2022/04/28 21:03
- PHP グローバルスコープはありますか? 1 2022/08/08 19:28
- 英語 中3英語 4 2023/01/31 14:03
- PostgreSQL 画像とカテゴリーを出力したいのですが、取得の条件を付ける方法がわかりません。 2 2022/05/01 18:03
- PostgreSQL 投稿記事と関連付けているテーブルがわからない 1 2022/04/27 20:29
- イベント・祭り イベントの話 2 2022/09/27 07:03
- PHP 'member_picture/'に/がありますが 、「スラッシュ」は必要でしょうか? 1 2022/11/27 04:32
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
重複するキーから一番古い年月...
-
2つのテーブルから条件に一致...
-
PLSQLの識別子エラー
-
履歴を管理するテーブル構造に...
-
行方向のデータを横に並べる
-
accessで移動平均する方法
-
DB2で助けてください!
-
続.ORACLEのSELECTのソートに...
-
項目内の改行がレコードの終わ...
-
VIEWでテーブルの集計結果...
-
正規化されていないテーブルの...
-
MySQLのgroup by同士の結合につ...
-
ACCESS2007 フォーム 「バリア...
-
SELECT文でのデッドロックに対...
-
sqlserverで集計結果をUPDATEし...
-
Access VBA [リモートサーバー...
-
オラクルではできるのにSQLSERV...
-
IFで条件を分岐させてのINSERT...
-
SI Object Browserのテーブルス...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
2つのテーブルから条件に一致...
-
重複するキーから一番古い年月...
-
主キーの変更
-
accessで移動平均する方法
-
ACCESS 一つのフィールドに複...
-
行方向のデータを横に並べる
-
update文で質問です。 下記の条...
-
PLSQLの識別子エラー
-
Accessでフィールドを比較した...
-
VIEWでテーブルの集計結果...
-
ACCESSのコンパイルエラーについて
-
下記のsqlで取得されるレコード...
-
SQL文のCOUNTについて
-
続.ORACLEのSELECTのソートに...
-
履歴を管理するテーブル構造に...
-
PLSQLで集計関数の値を配列に入...
-
アクセス2000のフォームに...
-
ACCESS2000です。
-
複数テーブルの不一致クエリに...
おすすめ情報