- ベストアンサー
access2000での抽出条件
DBから選択クエリーを作ってある条件を満たすデータを抽出したいのですが、レコードの量が多くて(10万単位)スぺックの悪いPCなので並べ替えをするにも固まってしまって困っています。 同じ名前を持つレコード群の中で最新の日付のレコードだけを抽出する関数ってありますか? 例えば 発生日,名前,種類,住所,電話番号 の5つのフィールドがあり、その中で同じ"名前"を持つ"発生日"の中で最新の日付だけを抽出する、として教えていただけないでしょうか。 よろしくお願いいたします。
- みんなの回答 (4)
- 専門家の回答
質問者が選んだベストアンサー
再度回答します。(最初の回答より掘り下げました) まずクエリーを作ります。(例:クエリー1) select * ← * にすると全フィールド項目が表示対象となります。 from DB名 where 名前 = 対象にしたい名前 order by 発生日 desc とすると最初の1件目があなたの欲しいデータとなります。(1件抽出にこだわらないなら。。。。) やはり、1件だけ欲しい場合は(少し遅くなる)、 そのクエリーに対して再度クエリーを作ります。(例:クエリー2) select * from クエリー1 group by 発生日,名前,種類,住所,電話番号; とします。 ※いきなり大量データをグループ化にすると遅くなるので、クエリー1で簡単抽出し、クエリー2でグループ化します。win95のaccess95でよくこの技を使いました。 あと比較記号で ≦ より > を記述する方が早くなるとかもあります。 抽出時に、日付で**/**/**などの形式の意識は入りません。 もしアクセス画面表示で形式のこだわった表示がしたいなら、表示項目のプロパティで書式をyyyy/mm/ddとすればいいでしょう。(format関数を使う方法もあるので書き出すときりがない) あとインデックスは貼ることができるなら貼った方がいいです。(方法は前回に回答済)
- 参考URL:
- http://www.e-taiko.co.jp/
その他の回答 (3)
- moisabc
- ベストアンサー率35% (7/20)
クエリーデザインを開き右クリックしSQLビューを開き、直接記述します。 select 最終日付 from DB名 where 名前=対照となる名前 order by 最終日付 desc 後、データベース定義で名前と最終日にインデックスを貼ればいい(重複あり) 私のパソコンで30万件のデータ検索で約4分でした。
- 参考URL:
- http://www.e-taiko.co.jp/
お礼
ありがとうございます。 うちのsql、規模小さいくせに支社からもみんなでアクセスしているのでやはり直接いじる事を躊躇してしまいました。もし壊したら私のスキルでは自信がないから・・ あと、質問なんですが今回の場合、各名前に対して最終日付(latest day)がバラバラなのですが、その場合は select日付の部分をどう書けばよいのか教えていただけないでしょうか?["00/*/*"or"99/*/*"]で使えますか? すみません,お願いします。
- poporo
- ベストアンサー率38% (10/26)
選択クエリなら簡単です。 1.グループ化をする。 2.「発生日」フィールドで「集計方法」を「最大」にする。 これだけでいいと思います。もし、グループ化がまずい場合は、「発生日」フィールドと「名前」フィールドだけのクエリと、「名前」「種類」「住所」「電話番号」フィールドのクエリを作って、ここから「名前」フィールドで繋ぎ合わせたクエリを作るといいと思います。 この場合は、「テーブル作成クエリ」などを利用して、「シリアル番号」フィールドを付け加えた「作業用のテーブル」を作ってしまう方がやりやすいと思います。
お礼
どうもありがとうございました。 チャレンジしてみたのですが結局最後までクエリーは開くことなく、ものすごくアナログにつぎはぎつぎはぎして テーブルを移した後クエリー抽出することで作業をムリヤリ終わらせました。
- myzard
- ベストアンサー率43% (68/156)
具体的な解決策ではないことをあらかじめ お断りしておきます。 レコード数が 10 万単位もあるということですが、 1 つのテーブルにそれだけあるということですよね。 ここはひとつ、データベースの構造を考え直すべきでは ないでしょうか。どのようなデータベースを作って いらっしゃるのか、もっと詳しく書いていただければと 思います。
補足
すみません、説明不足でした。 DB自体はsqlサーバ7.0にあります。 今回はその一部のデータをローカルに移しての作業を行っています。抽出作業自体はaccessで行っています。 一時的なものの為、sqlでの作業は出来るだけ避けたいと思っているので、access内でどうにかしたいのですが・・・。 よろしくお願いいたします。
お礼
どうもありがとうございます。 今回は時間がなかったので結局社内のexcelマスターにマクロをシコウサクゴしてやってもらってしまいました。情けない… とても分かりやすい説明で理解が出来たので次回からはできそうです。どうもありがとうございました。