DBから選択クエリーを作ってある条件を満たすデータを抽出したいのですが、レコードの量が多くて(10万単位)スぺックの悪いPCなので並べ替えをするにも固まってしまって困っています。

同じ名前を持つレコード群の中で最新の日付のレコードだけを抽出する関数ってありますか?

例えば
発生日,名前,種類,住所,電話番号
の5つのフィールドがあり、その中で同じ"名前"を持つ"発生日"の中で最新の日付だけを抽出する、として教えていただけないでしょうか。
よろしくお願いいたします。

A 回答 (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/
    • good
    • 0
この回答へのお礼

どうもありがとうございます。
今回は時間がなかったので結局社内のexcelマスターにマクロをシコウサクゴしてやってもらってしまいました。情けない…
とても分かりやすい説明で理解が出来たので次回からはできそうです。どうもありがとうございました。

お礼日時:-0001/11/30 00:00

クエリーデザインを開き右クリックしSQLビューを開き、直接記述します。


select 最終日付
from DB名
where 名前=対照となる名前
order by 最終日付 desc

後、データベース定義で名前と最終日にインデックスを貼ればいい(重複あり)
私のパソコンで30万件のデータ検索で約4分でした。

参考URL:http://www.e-taiko.co.jp/
    • good
    • 0
この回答へのお礼

ありがとうございます。
うちのsql、規模小さいくせに支社からもみんなでアクセスしているのでやはり直接いじる事を躊躇してしまいました。もし壊したら私のスキルでは自信がないから・・

あと、質問なんですが今回の場合、各名前に対して最終日付(latest day)がバラバラなのですが、その場合は
select日付の部分をどう書けばよいのか教えていただけないでしょうか?["00/*/*"or"99/*/*"]で使えますか?
すみません,お願いします。

お礼日時:-0001/11/30 00:00

選択クエリなら簡単です。


1.グループ化をする。
2.「発生日」フィールドで「集計方法」を「最大」にする。

これだけでいいと思います。もし、グループ化がまずい場合は、「発生日」フィールドと「名前」フィールドだけのクエリと、「名前」「種類」「住所」「電話番号」フィールドのクエリを作って、ここから「名前」フィールドで繋ぎ合わせたクエリを作るといいと思います。

この場合は、「テーブル作成クエリ」などを利用して、「シリアル番号」フィールドを付け加えた「作業用のテーブル」を作ってしまう方がやりやすいと思います。
    • good
    • 0
この回答へのお礼

どうもありがとうございました。
チャレンジしてみたのですが結局最後までクエリーは開くことなく、ものすごくアナログにつぎはぎつぎはぎして
テーブルを移した後クエリー抽出することで作業をムリヤリ終わらせました。

お礼日時:-0001/11/30 00:00

 具体的な解決策ではないことをあらかじめ


お断りしておきます。

 レコード数が 10 万単位もあるということですが、
1 つのテーブルにそれだけあるということですよね。
ここはひとつ、データベースの構造を考え直すべきでは
ないでしょうか。どのようなデータベースを作って
いらっしゃるのか、もっと詳しく書いていただければと
思います。

この回答への補足

すみません、説明不足でした。
DB自体はsqlサーバ7.0にあります。
今回はその一部のデータをローカルに移しての作業を行っています。抽出作業自体はaccessで行っています。
一時的なものの為、sqlでの作業は出来るだけ避けたいと思っているので、access内でどうにかしたいのですが・・・。
よろしくお願いいたします。

補足日時:2000/12/06 18:06
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

今、見られている記事はコレ!

  • 縦書きと横書きはどちらが読みやすい?

    普段何気なく読んでいる文章ですが、縦書きか横書きか、意識したことはありますか?制作側としては読み手はどちらの方が読みやすいと思うかはとても大きな問題です。教えて!gooには、 「『横書き』と『縦書き』、...

  • 昭和の日ってどういう日?

    ゴールデンウィーク初日の4月29日は「昭和の日」です。今や平成生まれの人も多い時代ですが、「なぜ昭和の日があるの?」という疑問をもったことはありませんか?和暦を挙げるのなら、大正の日、明治の日、平成の日...

  • Excelの意外な使い方とは?

    会社のパソコンに必ず入っている、と言っても過言ではない、Office系ソフトの「Word」と「Excel」。PCを使う職場にいた方なら、一度は触ったことがあるかと思います。Wordは仕事以外に使う方法がすぐ浮かびそうです...

  • がんになったら!?二度のがんを乗り越えた経営者に聞く治療のポイントと心構え

    日本人の三大疾病の一つである「がん」。二人に一人が、一生のうち一度はがんになるというデータもある。最近では歌舞伎俳優・市川海老蔵さんの妻、小林麻央さんが自らのがん闘病についてブログで伝え、話題になった...

  • ゲーム業界ダンナ観察日記:第95話「謎企画」

    ダンナ様のねむねむ。奥様のとぽすけ。ごく普通のふたりは、ごく普通の結婚をし、だらだらと夫婦生活を送っていました。でもただひとつ違っていたのは、ダンナ様はゲーム会社勤務だったのです。

おしトピ編集部からのゆる~い質問を出題中

お題をもっとみる

このQ&Aを見た人が検索しているワード


このカテゴリの人気Q&Aランキング

おすすめ情報

カテゴリ