C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.18769 の関連記事表示

<< 0 >>
■18769  ■日付期間の取得及びチェック
□投稿者/ ooo -(2008/05/16(Fri) 09:56:06)

    分類:[ASP.NET (VB)] 

    ■日付期間の取得及びチェック

    ☆環境
     ・VS2005
    ・VB.NET
    ・Webアプリ ASP.NET2.0

    皆様、お世話になります。
    下記の問題に直面してしまいましたので、みなさまの知恵をお貸しください。

    開始日 終了日
    |----------|----------|
    1|2007/01/01|2007/02/01|
    |----------|----------|
    2|2008/02/21|2008/03/01|
    |----------|----------|
    3|2007/01/02|2007/02/02|
    |----------|----------|

    上記のような構造のデータがあったと考えて、
    開始日〜終了日の期間が重複するレコードが存在する場合はエラーとします。

    この例でいうと、1レコード目と3レコード目は期間が重複しているため、エラーとなります。

    エラーのチェックの方法ですが、開始日〜終了日 の期間を別のレコード分1件づつループでと比較する方法
    が思い浮かびますが、判定方法のイメージがつきません。

    なにか、案があったらご教授いただけませんでしょうか。

    よろしくお願いいたします。
親記事 /過去ログ36より / 関連記事表示
削除チェック/

■18771  Re[1]: ■日付期間の取得及びチェック
□投稿者/ ふるふる -(2008/05/16(Fri) 10:11:32)
>
    こんにちは。

    2つ(AとBとしましょう)の開始日と終了日での期間重複チェックであれば、
    A.開始日<=B.終了日 AND A.終了日>=B.開始日
    でいいかと。
    当然ながら開始日<終了日 です。また=が成り立っていいかどうかは仕様によります。



    No18769 (ooo さん) に返信
    > ■日付期間の取得及びチェック
    >
    > ☆環境
    >  ・VS2005
    > ・VB.NET
    > ・Webアプリ ASP.NET2.0
    >
    > 皆様、お世話になります。
    > 下記の問題に直面してしまいましたので、みなさまの知恵をお貸しください。
    >
    > 開始日 終了日
    > |----------|----------|
    > 1|2007/01/01|2007/02/01|
    > |----------|----------|
    > 2|2008/02/21|2008/03/01|
    > |----------|----------|
    > 3|2007/01/02|2007/02/02|
    > |----------|----------|
    >
    > 上記のような構造のデータがあったと考えて、
    > 開始日〜終了日の期間が重複するレコードが存在する場合はエラーとします。
    >
    > この例でいうと、1レコード目と3レコード目は期間が重複しているため、エラーとなります。
    >
    > エラーのチェックの方法ですが、開始日〜終了日 の期間を別のレコード分1件づつループでと比較する方法
    > が思い浮かびますが、判定方法のイメージがつきません。
    >
    > なにか、案があったらご教授いただけませんでしょうか。
    >
    > よろしくお願いいたします。
記事No.18769 のレス /過去ログ36より / 関連記事表示
削除チェック/

■18770  Re[1]: ■日付期間の取得及びチェック
□投稿者/ はつね -(2008/05/16(Fri) 10:04:19)
>
    No18769 (ooo さん) に返信
    > エラーのチェックの方法ですが、開始日〜終了日 の期間を別のレコード分1件づつループでと比較する方法
    > が思い浮かびますが、判定方法のイメージがつきません。
    
    「期間が重なる」というアヤフヤな定義ではなく、箇条書きでもいいので
    期間が重なる条件を列挙してみたらどうでしょうか。
    
    例)
    ・「判定元の開始日<=開始日」かつ「判定元の終了日>=開始日」
        または
    ・「・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・
        または
         :
         :
    
    
    
記事No.18769 のレス /過去ログ36より / 関連記事表示
削除チェック/

■18772  Re[2]: ■日付期間の取得及びチェック
□投稿者/ れい -(2008/05/16(Fri) 10:23:14)

    開始日でレコードをソートすれば、
    1回に2レコード、3セルを見るだけいけますね。

    ソートがnlog(n)ですから、nlog(n)+nで判定できることになります。
記事No.18769 のレス /過去ログ36より / 関連記事表示
削除チェック/

■18797  Re[3]: ■日付期間の取得及びチェック
□投稿者/ ooo -(2008/05/16(Fri) 12:22:01)
    はつねさん
    ふるふるさん
    れいさん

    ご回答いただきましてありがとうございます。

    >「期間が重なる」というアヤフヤな定義ではなく、箇条書きでもいいので
    >期間が重なる条件を列挙してみたらどうでしょうか。

    確かに、「期間の重複」という定義では、曖昧ですね。
    プログラムを作成する際にフローを書くようにすると基本的なことが抜けていました。

    ふるふるさんのアドバイスで検証したところ、うまくいったように見受けられます。

    ありがとうございました。

記事No.18769 のレス / END /過去ログ36より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -