![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
失礼致します。
joinについて勉強しています。
下記サイトで手ごろな例題を見つけました。
<http://www.atmarkit.co.jp/fnetwork/rensai/sql04/ …
ここで、
SELECT OrderID, Prd.ProductID, ProductName, Prd.UnitPrice, Quantity, Discount
FROM "Order Details" Ord
INNER JOIN Products Prd ON Ord.ProductID=Prd.ProductID
という記述があるのですが、これはjoinを使わず
SELECT Ord.OrderID, Prd.ProductID, Ord.ProductName, Prd.UnitPrice, Ord.Quantity, Ord.Discount
FROM "Order Details" Ord, "Products" Prd
WHERE Ord.ProductID=Prd.ProductID
とするのと何が違うのでしょうか?
また、INNER JOINやLEFT JOINなどの例はよく見るのですが、
単純な(頭に何も付かない)JOINは何を意味するのでしょうか?
以上、よろしくお願いします。M(_ _)M
No.3ベストアンサー
- 回答日時:
単なるJOINがINNER JOINであることは、他の方と同じです。
SELECT * FROM A,B WHERE ~
とした場合と
SELECT * FROM A INNER JOIN B ON ~ WHERE ~
JOINを使った場合との差ですが、
速度面については、各DBサーバーのよって異なるのでなんとも言えませんが、SQL文作成担当の目線(つまり人の目線)で言えば、
テーブルの結合条件と 絞込み条件を分けられるか否かが大きいと思っています。
SELECT * FROM A,B WHERE ~
の場合、WHERE以降に結合条件 と 絞込み条件 が混ざってしまいます。
一方、SELECT * FROM A INNER JOIN B ON ~ WHERE ~
ON以降に結合条件、WHERE以降に絞込み条件 と分かれます。
個人的には、結合するテーブルが少なかったり、絞り込む条件が少なかったりすれば、どちらでも良いですが、
テーブルが多くなったり、絞り込む条件が複雑になったり(しかもorが入ったりしてANDで結ぶには括弧が必要なる とか・・・)、したときに、明確に分けられるJOIN 形式が好きです。
ご回答ありがとうございました。
なるほど、テーブルの結合条件とResultSetとして取り出す
レコード条件を分けて記述できる点が便利なのですね。
このポイントはかなり重要だと思います。
ありがとうございました。
No.4
- 回答日時:
一緒です。
結果も処理性能も差はありません。SQLの意味を解析し、最適化した時点で、両者に差は無くなりますから。
#逆に、あったらそのRDBMSは実装が怪しい。実行時の最適化がされていない可能性がある。
Oracleは逆に、JOINではなくWHERE句の=で結合しますし、左右の外部結合もWHERE句でやります。
>Oracleは逆に、JOINではなくWHERE句の=で結合しますし、左右の外部結合もWHERE句でやります。
参考になります。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- PostgreSQL SQLで検索結果の記事を表示したい 1 2022/04/28 21:03
- PostgreSQL 画像とカテゴリーを出力したいのですが、取得の条件を付ける方法がわかりません。 2 2022/05/01 18:03
- MySQL PhpMyAdminで作成して実行せよ。 東京23区を、皇居を中心とした4つのエリア(南東, 南西, 1 2023/06/11 11:58
- Access(アクセス) アクセス 削除するレコードを含んだテーブルを指定してくださいのエラー対処方法 1 2022/11/24 15:01
- Oracle SQL update方法 2 2022/06/22 14:07
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
- Oracle 質問です。 下記のテーブルとデータがあり、 取得想定結果のように出力したいです。 下記のsqlだと0 2 2023/05/23 19:10
- MySQL 複数DBテーブルからのデータ取得 3 2022/05/17 15:02
- PostgreSQL 投稿記事と関連付けているテーブルがわからない 1 2022/04/27 20:29
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
外部キーのリレーションが設定...
-
select文の戻り値を変数に格納...
-
DBの読み込み順について
-
SQL文(テーブル項目名が特殊文...
-
Windows formアプリで データグ...
-
accessのフォームを使ってテー...
-
異なるデータベースでのSELECT ...
-
【ACCESS】リレーションを組ん...
-
ExcelVBAを使って、値...
-
データ数をカウントしたいのですが
-
i=cells(Rows.Count, 1)とi=cel...
-
Accessのクエリで、replace関数...
-
VB.NETで DataRow()を利用して...
-
count(*)で取得した値をJAVAの...
-
特定のセルが空白だったら、そ...
-
Excelのセルの色指定をVBAから...
-
Excle VBA Findメソッドについて
-
テキストボックスのvalueとtext...
-
Listviewのデータを上から順番...
-
【Excel VBA】指定行以降をクリ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Windows formアプリで データグ...
-
【ACCESS】リレーションを組ん...
-
select文の戻り値を変数に格納...
-
SQL文(テーブル項目名が特殊文...
-
ACCESSテーブルを RecordSet以...
-
DBの読み込み順について
-
外部キーのリレーションが設定...
-
access コンボボックス初期表示...
-
Perlで変数内の日本語が文字コ...
-
VBとACCESSを接続したい
-
テーブルというグローバル変数
-
C# 型名に変数が使えますか?
-
ASP.NET:複数結合テーブルのデ...
-
ASPとAccessとの接続について
-
accessのフォームを使ってテー...
-
Delphi BDE 複数ユーザによる...
-
DataGridViewで編集した内容を...
-
SQLで最新の3件分の統計をとりたい
-
モデルクラスの数は?テーブル...
-
教えてアクセス2007!「在...
おすすめ情報