ここから本文です

Access,クエリ,日付表示での質問です。例:2010/9/1表示をAの場合:2010/9/25,B...

杏仁さん

2010/9/815:12:20

Access,クエリ,日付表示での質問です。例:2010/9/1表示をAの場合:2010/9/25,Bの場合:2010/9/30と表示させたい場合はどうすればいいのでしょうか。Bの場合,当然10月は2010/10/31と表示させたいです。

補足回答ありがとうございます。Aは25日締め、Bは月末締めです。検収日の項目があり、検収日とAかBで検収月を計算式で出しています。その結果が1日付けになるのです。何かいい方法はないでしょうか。

閲覧数:
846
回答数:
1
お礼:
50枚

違反報告

ベストアンサーに選ばれた回答

mi_********さん

編集あり2010/9/823:22:58

> 2010/9/1表示をAの場合:2010/9/25,Bの場合:2010/9/30と表示させたい場合はどうすればいいのでしょうか。Bの場合,当然10月は2010/10/31と表示させたいです

Bの場合はその月の末日だというのは推測できますが、Aの場合はどういう日付なのでしょうか?

たとえば、フィールド1が日付/時刻型で、そこに月の1日が入っているのであれば、その月の末日は、1か月後(つまり翌月の1日)の前日を求めればOKです。

なので

B: DateAdd("d",-1,DateAdd("m",1,[フィールド1]))

でどうでしょう。
Aについては、条件が不明なので、何とも言えませんが、もし、その月の最後の土曜日という意味なら

A: DateAdd("d",-1,DateAdd("m",1,[フィールド1]))-Weekday(DateAdd("d",-1,DateAdd("m",1,[フィールド1])))

では?



*追記*


> Aは25日締め、Bは月末締めです。

ということは、A は必ずその月の25日を出せばいいのでしょうか?
それなら

A: DateAdd("d",24,[フィールド1])




> 検収日の項目があり、検収日とAかBで検収月を計算式で出しています。その結果が1日付けになるのです。


検収日から1日の日付を求める式がわからないので、正確には記述できませんが、たとえば

IIf([締めパターン]='A',DateSerial(Year([検収日]),Month([検収日]),1),DateSerial(Year([検収日]),Month([検収日])+1,1))

のような式で1日の日付を求めているのであれば(上の式はあくまでも想像で書いたもので正確ではありませんので念のため)

A: DateAdd("d",24,IIf([締めパターン]='A',DateSerial(Year([検収日]),Month([検収日]),1),DateSerial(Year([検収日]),Month([検収日])+1,1)))

B: DateAdd("d",-1,DateAdd("m",1,IIf([締めパターン]='A',DateSerial(Year([検収日]),Month([検収日]),1),DateSerial(Year([検収日]),Month([検収日])+1,1))))

のようなことでしょうか。



それとも A か B かで求める日付を切り替えて

IIf([締めパターン]='A',DateAdd("d",24,[フィールド1]),DateAdd("d",-1,DateAdd("m",1,[フィールド1])))

のようなことなのでしょうか?

質問した人からのコメント

2010/9/9 08:59:55

降参 ありがとうございました。質問についての説明不足のようです。新たに質問させて頂くと思いますので,よかったらまたアドバイスをお願いします。

この質問につけられたタグ

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる