

ある年月に一番近い大きな日付を1件取得したいと思っています。
ある年月は40000件くらいあります。
一番早く実行できる方法を探しています。
対象となるデータを全部DataTableに取得し
LINQで何度も検索するのがいいのかと思いつきました。
全部取得するときに年月を降順に指定すると
Dim datarecord = (From animal In tbData Where animal.Field(Of Date)("年月") <= ある年月 Select animal).First
で一番近い大きな年月が取得できることが保証されるのでしょうか?
それともSQLでは何も指定せずLINQで順番を指定するのが早いのでしょうか?
No.1ベストアンサー
- 回答日時:
LINQは基本的には遅延評価にメリットを求めたほうがよいと思います。
速度的には列挙体を検索するのとあまり変わらないです。
DataTableにはSelectメソッドがありますことらを利用すればよいのではないでしょうか?
まずLINQより早いです。
http://www.yel.m-net.ne.jp/~oss/Tips/ADO/Tips_01 …
この回答への補足
ありがとうございます。
やってみましたがLINQの方が早く処理が終わりました。
'DataTableにSelect
Do Until getCalcDate < minCalcDate
'Dim datarecord = tbData.Select("年月<=#" & getCalcDate & "#", "年月 DESC")
'取得した1行目の合計を計算
XXXXXXXX
'次の検索する年月の作成
getCalcDate = DateAdd(DateInterval.Minute, 1, getCalcDate)
Loop
'LINQで検索
Do Until getCalcDate < minCalcDate
Dim datarecord = (From animal In tbData Where animal.Field(Of Date)("年月") <= getCalcDate Order By animal.Field(Of Date)("年月") Descending Select animal).First
'取得した1行目の合計を計算
XXXXXXXX
'次の検索する年月の作成
getCalcDate = DateAdd(DateInterval.Minute, 1, getCalcDate)
Loop
LINQをDo Uintilの外に出すと
結果が間違って返ってきます。
No.3
- 回答日時:
Dim datarecord = (From animal In dt Where animal.Field(Of Date)("年月") <= getCalcDate And animal.Field(Of Date)("年月") >= minCalcDate Order By animal.Field(Of Date)("年月") Descending Select animal)
For Each field In datarecord
Console.WriteLine(field("年月"))
Next
ではどうでしょうか?
試してみましたが効果が得られませんでした。
SQLを何回も発行するほうが何倍も早かったので
LINQはあきらめました。
環境と作り方によって変わるので
合っているものを選んでいこうと思います。
何度もお返事ありがとうございました。
No.2
- 回答日時:
提示していただいたソースであれば、LINQのほうがダントツで早いです、なぜかというと、抽出が実行されていないからです。
LINQは遅延評価を行います、結果を参照されてたときに始めてクエリが実行される仕組みです。
そのため、
XXXXXXX
となっている部分を、何か参照するロジックに変更してください。
3回くらい参照するようにすれば、その差は歴然です。
これを解決する方法は、
datarecord.ToList<>などの変換メソッドのどれかを利用しコピーを作成してからアクセスするようにします。
話を戻します。
LINQは遅延評価ですので、参照されるたびに条件式で評価しなおします。
そのため、そのときのDataTableの内容を評価した結果を返してきます。
条件によっては参照するたびに違った結果を出すことも可能というわけです。
この回答への補足
早そうな遅延評価を実行させるように
プログラムを書き換えました。
でもうまくできませんでした。
「シーケンスに要素が含まれていません」
が表示されます。
Dim getDate As Date 'ある年月
Dim tbData As DataTable 'データ
Dim total as Decimal '合計値
tbData にテーブルデータ取得
Dim datarecord = (From animal In tbData Where animal.Field(Of Date)("年月") <= getCalcDate Order By animal.Field(Of Date)("年月") Descending Select animal).First
'対象年月分ループ
Do Until getCalcDate < 最小日付
total +=datarecord("データ")
getCalcDate = (getCalcDate を減らす式)
Loop
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Oracle 質問です。 下記のテーブルとデータがあり、 取得想定結果のように出力したいです。 下記のsqlだと0 2 2023/05/23 19:10
- Visual Basic(VBA) エクセルのマクロコードの一部分を変更する方法について教えてください。 2 2023/02/17 08:40
- Visual Basic(VBA) 指定月分の顧客データファイルを統合して並べ替え、所定の場所に貼り付ける 3 2022/09/10 07:55
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- その他(プログラミング・Web制作) python 気象データの取得 2 2023/06/20 23:54
- MySQL SQLです。下記の問合せを行うクエリを、PhpMyAdminで作成して実行せよ。 「昨年の各月の総降 1 2023/07/01 00:32
- 投資・株式の税金 一般口座で同一銘柄の総平均法のことで 1 2023/02/27 22:08
- MySQL SQL任意に並び替えをしたい 2 2023/08/28 10:47
- 運転免許・教習所 社用車を使う仕事で、昔免許取消しになっている場合は、それがバレたときクビになると思いますか? 一度病 9 2022/09/16 17:45
- Visual Basic(VBA) 指定月分の顧客データファイルを統合して並べ替え、所定の場所に貼り付ける (再質問) 4 2022/09/14 22:51
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VB.NETで DataRow()を利用して...
-
VBAでActiveDirectoryのユーザ...
-
JavaScriptでリンク先やリモー...
-
ListView 項目の選択/選択解除...
-
count(*)で取得した値をJAVAの...
-
PHP8でWarning:Undefined varia...
-
VBA:小数点以下の数字を取得で...
-
JavaScriptにおいてコンピュー...
-
利用者側のMACアドレスを取得し...
-
like演算子内に変数って使えな...
-
getParameter と getAttribut...
-
ListViewで複数選択された項目...
-
LVM_HITTEST
-
VBA リストボックス複数選択か...
-
NTPサーバから時刻を取得する
-
C# 仮想リストビュー
-
Xcodeプログラミング大全という...
-
リストボックスの値の取得
-
EXCELのリストボックスを選択し...
-
C#とwindows APIとの連動方法
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VB.NETで DataRow()を利用して...
-
ListView 項目の選択/選択解除...
-
VBA:小数点以下の数字を取得で...
-
VBAでActiveDirectoryのユーザ...
-
Spreadの選択行の取得について
-
PHP8でWarning:Undefined varia...
-
Flexgridで選択行の列の値を取...
-
count(*)で取得した値をJAVAの...
-
VBA Shapesの座標からセル位置...
-
データ数をカウントしたいのですが
-
JavaScriptにおいてコンピュー...
-
利用者側のMACアドレスを取得し...
-
VBA リストボックス内の値を複...
-
like演算子内に変数って使えな...
-
EXCELのリストボックスを選択し...
-
「Excel VBA」 Webクエリ マク...
-
JavaScriptでWindowsログオンID...
-
gethostbyaddrでのホスト名取得...
-
現在時刻をミリ秒まで取得
-
vbaで、オートシェイプ文字幅と...
おすすめ情報