お世話になります
現在Access2000で、営業週報のレポートを作成しています。
営業が毎日入力するデータを一週間毎に週報としてAccessのレポートで出したいのですが、行き詰まってる個所があります。
やりたいことは、
===================
営業週報 7/5~7/9
山田太郎
※日付 |※行動
7/5(月) |挨拶
7/6(火) |商談
7/7(水) |見積もり
7/8(木) |見積もり
7/9(金) |納入
==================
※はフィールド名
↑のように、ごくごく簡単なレポートです。(説明の為フィールドは省略してあります。)
一週間の日付と、その日に何をしたかという事がわかればOKなんです。しかし、営業も日報を入力しない日というのがありますので、全ての曜日にデータが埋まるこということがなかなかりません。
ここで例えば、7/6(火)の日報がない場合は
===================
営業週報 7/5~7/9
※日付 |※行動
7/5(月) |挨拶
7/7(水) |見積もり
7/8(木) |見積もり
7/9(金) |納入
==================
当然ですが、7/6レコードが丸々抜けてしまうのです。
これだとNGなので、7/6日の日報がない場合でも
===================
営業週報 7/5~7/9
※日付 |※行動
7/5(月) |挨拶
7/6(火) |
7/7(水) |見積もり
7/8(木) |見積もり
7/9(金) |納入
==================
このように日付だけは表示されて
「ああ、7/6はどこも行かなかったのね」
とわかるようにしたいのですが、
何かよい方法はありませんでしょうか?
説明が長くなりましてすみません、
足りない部分があれば補足いたします。
どうぞよろしくお願いします。
No.3ベストアンサー
- 回答日時:
VBA を使わないでもできるのかもしれないですが、やはり VBA を使った方が簡単になるように思います。
フォーム上のテキスト0に 2004/08/16 のように日付が入っていてた場合、2004/08/16 ~ 2004/08/20 をテーブル T_日付(日付フィールドが主キー)に追加するなら、例えば
Private Sub コマンド4_Click()
Dim s As String
Dim d As Date
Dim i As Integer
Dim db As Database
Set db = CurrentDb
d = CDate(Me.テキスト0)
For i = 0 To 4
s = "INSERT INTO T_日付 ( "
s = s & "日付 ) "
s = s & "VALUES ( "
s = s & "#" & Format(d, "yyyy/mm/dd") & "#)"
On Error Resume Next
db.Execute s
On Error GoTo 0
d = DateAdd("d", 1, d)
Next i
End Sub
にようにすればできます。
( ↑のコードは DAO を使用してますので、VBA のメニューのツール→参照設定で DAO にチェックを入れてください。)
他にも、パラメータクエリーにするとか、いろいろな方法があると思います。
素晴らしいです!これでなんとかできそうです
VBAは初心者なのですが、使いこなせればずいぶん楽になりそうですね。
ご丁寧なアドバイスありがとうございました。
No.2
- 回答日時:
> ↑の部分はやはりVBAを使わないとできない処理でしょうか?
事前に1年分とかの日付のみデータを作成しておいて、期間で抽出してやれば
大丈夫だと思いますよ。
Excelなどを使えば、簡単に作成できますので。
No.1
- 回答日時:
(1) 日付だけのテーブルと
(2) 日付、行動のフィールドを持つテーブル
の二つのテーブルに分け、
(1) と (2) を元にクエリーを作成し、(1) → (2) の向きの外部結合( (1) のレコードを全て含む)にしてやってはどうでしょか。
(1) のレコードを作成するタイミングは、レポートの出力実行時(イベントプロシージャの先頭)とかにし、登録されていない日付だけ登録するようにするなどしなければならないと思います。
さっそくのご解答ありがとうございます。
さっそく実行してみます!と言いたいのですが・・
>登録されていない日付だけ登録するようにするなどしなければならないと思います。
↑の部分はやはりVBAを使わないとできない処理でしょうか?
重ね重ねで恐縮ですがよろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
SQL文で パラメータが少なすぎ...
-
日付型のフィールドに空白を入...
-
Excleピボットでデータのない部...
-
指定日付を起点にして最新日付...
-
Accessの日付時刻型から日付、...
-
VBA 別シートの同じ日付の欄に...
-
クロス集計のユニオンクエリー...
-
Access クエリで、レコードの無...
-
BCPでCSV内の文字列をテーブル...
-
ACCESS フォームの非連結の日...
-
アクセスで月単位の抽出
-
Excel→Accessへの日付データの...
-
Accessクエリで、予定した日付...
-
VBAでの年齢計算がうまくいきま...
-
アクセス:既定値に土日含まず...
-
Access dcount 複数条件
-
Access2007での売掛残の抽出
-
アクセスの昇順並び替えで空白...
-
ACCESSの空白をカウントする
-
accessの時間更新方法(フォーム)
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
日付型のフィールドに空白を入...
-
SQL文で パラメータが少なすぎ...
-
Excleピボットでデータのない部...
-
VBA 別シートの同じ日付の欄に...
-
アクセス:既定値に土日含まず...
-
Excel→Accessへの日付データの...
-
指定日付を起点にして最新日付...
-
【エクセル】指定した日付に一...
-
Accessの日付時刻型から日付、...
-
BCPでCSV内の文字列をテーブル...
-
アクセスで月単位の抽出
-
Access クエリで、レコードの無...
-
【Accessで困っています...
-
ACCESSの空白をカウントする
-
エクセル-過去6カ月分の合計を...
-
【vba】日付の形式が勝手に変わ...
-
Accessのデータ型の日付/時刻型...
-
アクセス97のVBAで日付項目をヌ...
-
アクセスの昇順並び替えで空白...
-
ビュー定義をプログラムで動的...
おすすめ情報