C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.648 の関連記事表示

<< 0 >>
■648  Re[1]: Oracle のsql文について
□投稿者/ Jitta -(2005/06/20(Mon) 22:43:22)

    分類:[VB.NET] 

     Oracle10gということですから、WHERE句で結合するのではなく、JOINで結合しましょう。これの利点は、結合条件と抽出条件を分離できるところです。元のSQL文を書き直すと、次のようになります。

    SELECT a.code, a.name, SUM(b.kin), SUM(b2.kin2)
     FROM a
      INNER JOIN b
       INNER JOIN b2 ON b.code2 = b2.code2
      ON a.code = b.code
     GROUP BY a.code, a.name
     ORDER BY a.code

     しかしこれ、データの主体はB表ですから、B表から取得するようにすると、わかりやすくなりますね。

    SELECT a.code, a.name, SUM(b.kin), SUM(b2.kin2)
     FROM b
     INNER JOIN a ON a.code = b.code
     INNER JOIN b2 ON b2.code2 = b.code2
     GROUP BY a.code, a.name
     ORDER BY a.code


    > なぜ、教えてGooで断わりも無く、マルチポストをするのですか。
     マルチ"サイト"ポストの悪評を高くするため。

     gooで回答がついたからといってこちらをうっちゃっていると、こちらでは誰も回答してくれなくなりますよ > 元質問者

記事No.637 のレス /0過去ログ1より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -