• ベストアンサー

Select Distinctについて

SQL文の質問です。フィールドがTable1に100つあるとします。 select distinct XYZ From Table1という文があるとします。 これだとXYZのフィールドしか参照していないことになると思います。 そうではなくて、他の99フィールドの値も参照(データにアクセスしたい)したいと思っています。 select distinct XYZ, * From Table1とSelect * from Table1みたいなことをやりましたがエラーが発生しました。他の99フィールドを参照する方法はあるでしょうか?

質問者が選んだベストアンサー

  • ベストアンサー
  • anmochi
  • ベストアンサー率65% (1332/2045)
回答No.1

 DISTINCTは、最も単純でかつやや不正確な意味は「あるテーブルの中身を取ってくる時に列を絞ったら同じ行が複数出てきたから一つだけにしましょう。」という事だよね。  例:ある講義を、ユーザーが何回受講したか登録するテーブルD_JUKOU。PKはCLASSIDとUSERIDとしよう。 | CLASSID | USERID | TIMES | | 1 | A | 20 | | 1 | B | 1 | | 2 | B | 99 | | 2 | C | 2 |  この中から「誰かに一回でも受講された講義」一覧を作りたい。 SELECT CLASSID FROM D_JUKOU この時、1をAさんBさんが、2をBさんCさんが受講しているので1も2も2件出てきますな。ここで欲しいのは講義一覧なのでそういう重複を省きたいわけだ。 SELECT DISTINCT CLASSID FROM D_JUKOU これで受講した人数に関わらず各講義が1回ずつ現れるようになる。さて、これをUSERIDとTIMESも含めるとどうなるだろう。 SELECT DISTINCT CLASSID, USERID, TIMES FROM D_JUKOU 講義が同じでもユーザーと回数が違うレコードがあるのでそれらは重複でなく、当然省略されない。なので > これだとXYZのフィールドしか参照していないことになると思います。 XYZのフィールドしか参照しなくてそこで重複が出るから重複を一回ずつにするのがDISTINCTの目的だ。仮にDISTINCTで重複を省いた一覧を作った後それを元のテーブルと結合(INNER JOIN)したとしても、せっかく省かれた重複がまた元通りに結合されるのでまったく意味がない。重複を省いた後で他の99フィールドを参照する時に、省かれたどっちを参照したいのかDBMSは分からないからね。なので、それを、たとえば「重複があった場合は一旦重複を省いて1件ずつにした後、XYZ列の値が同じものの中でABC列の値が最も若いものを選択する」などという条件を加える事ができるのであればサブクエリを使って実現できる。そういう条件が無いのであればそもそもDISTINCTを使うという選択がおかしいって事になる訳です。

その他の回答 (1)

  • nda23
  • ベストアンサー率54% (777/1415)
回答No.2

全フィールドを使ってDISTINCTしたいのならば、SELECT DISTINCT * ですね。でも。欲しいのはXYZフィールドだけ・・・ じゃあ、SELECT DISTINCT * したものからXYZだけ取り出せば良い訳 ですね。 SELECT XYZ FROM (SELECT DISTINCT * FROM Table1) こんな感じでいかがでしょう。