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

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

C# と VB.NET の入門サイト

Re[3]: ■日付期間の取得及びチェック


(過去ログ 36 を表示中)

[トピック内 5 記事 (1 - 5 表示)]  << 0 >>

■18769 / inTopicNo.1)  ■日付期間の取得及びチェック
  
□投稿者/ ooo (6回)-(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件づつループでと比較する方法
が思い浮かびますが、判定方法のイメージがつきません。

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

よろしくお願いいたします。  

引用返信 編集キー/
■18770 / inTopicNo.2)  Re[1]: ■日付期間の取得及びチェック
□投稿者/ はつね (698回)-(2008/05/16(Fri) 10:04:19)
はつね さんの Web サイト
No18769 (ooo さん) に返信
> エラーのチェックの方法ですが、開始日〜終了日 の期間を別のレコード分1件づつループでと比較する方法
> が思い浮かびますが、判定方法のイメージがつきません。

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

例)
・「判定元の開始日<=開始日」かつ「判定元の終了日>=開始日」
    または
・「・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・
    または
     :
     :



引用返信 編集キー/
■18771 / inTopicNo.3)  Re[1]: ■日付期間の取得及びチェック
□投稿者/ ふるふる (6回)-(2008/05/16(Fri) 10:11:32)
ふるふる さんの Web サイト
こんにちは。

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件づつループでと比較する方法
> が思い浮かびますが、判定方法のイメージがつきません。
>
> なにか、案があったらご教授いただけませんでしょうか。
>
> よろしくお願いいたします。
引用返信 編集キー/
■18772 / inTopicNo.4)  Re[2]: ■日付期間の取得及びチェック
□投稿者/ れい (544回)-(2008/05/16(Fri) 10:23:14)

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

ソートがnlog(n)ですから、nlog(n)+nで判定できることになります。

引用返信 編集キー/
■18797 / inTopicNo.5)  Re[3]: ■日付期間の取得及びチェック
□投稿者/ ooo (7回)-(2008/05/16(Fri) 12:22:01)
はつねさん
ふるふるさん
れいさん

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

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

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

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

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


解決済み
引用返信 編集キー/


トピック内ページ移動 / << 0 >>

このトピックに書きこむ

過去ログには書き込み不可

管理者用

- Child Tree -