

ある年月に一番近い大きな日付を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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VB.NETで DataRow()を利用して...
-
count(*)で取得した値をJAVAの...
-
利用者側のMACアドレスを取得し...
-
バージョンナンバーの取得
-
アクセスしてきたコンピュータ...
-
ファイル名の取得について
-
VBでインストール済みアプリケ...
-
vbaで、オートシェイプ文字幅と...
-
コンボボックス表示文字列を取...
-
ListView 項目の選択/選択解除...
-
Flexgridで選択行の列の値を取...
-
VB .netにて現在時刻+1時間後...
-
getParameter と getAttribut...
-
MACアドレスを取得する方法はあ...
-
PHP8でWarning:Undefined varia...
-
データ数をカウントしたいのですが
-
strftimeについて
-
C言語でマウスカーソルハンド...
-
URIでのページの移動について
-
ディスプレイの表示可能な解像...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VB.NETで DataRow()を利用して...
-
PHP8でWarning:Undefined varia...
-
データ数をカウントしたいのですが
-
VBAでActiveDirectoryのユーザ...
-
ListView 項目の選択/選択解除...
-
count(*)で取得した値をJAVAの...
-
利用者側のMACアドレスを取得し...
-
Flexgridで選択行の列の値を取...
-
VBA:小数点以下の数字を取得で...
-
JavaScriptにおいてコンピュー...
-
Spreadの選択行の取得について
-
ASP(vbscript)におけるクライア...
-
エクセルVBAで複数選択できるよ...
-
asp.netでtextboxの値を取得
-
コンボボックス表示文字列を取...
-
現在時刻をミリ秒まで取得
-
EXCELのリストボックスを選択し...
-
Excel VBA でログインしてい...
-
URIでのページの移動について
-
VBA リストボックス内の値を複...
おすすめ情報