Am in the process of making changes - question regarding month...
Identifying the months by their number helps keep things in chronologic
order (combo lists). When I'm ready to extract reports for the boss
that
will display a list of our reports that are due, how do I get rid of
the
month number and replace it with the month name?
Originally, I had created a table of just the month names (because I could
not get a date field to only display month or month and day without
year) but
when I used that table as a combo list, it automatically sorted in
alpha
order, forcing the months to not be chronological - pushing the need
for
numbered months, but the boss doesn't like to see numbered months, he likes
names - he also wanted the data entry person to be able to select the month
by number or month name - but I never got that working.
Thanks for your help, I need to close out this project and move on to
the
next, hopefully restructuring the tables will resolve this issue.
Most Appreciative - Suzanne
:
Your table of months is a trouble maker and your idea to scrap it is
a good
one! I suggest the following tables:
TblAgency
AgencyID
AgencyName
TblReport
ReportID
AgencyID
ReportName
OnlyUponRequest Yes/No
TblReportDue
ReportDueID
ReportID
ReportDueMonth (1 to 12)
ReportDueDay
TblReportDue is necessary because if a report is due multiple times during
the year, you need multiple records to show this in TblReportDue. All your
queries that show something about when a report is due need to
include the
OnlyUponRequest field. If you want to find what reports are due at a certain
month and day, you need to set the criteria of OnlyUponRequest to
False and
include TblReportDue in your query. If you want to find only the
reports
that are due upon request, you would set OnlyUponRequest to True and
you
don't need TblReportDue in your query.
Sample queries:
1. To find the reports due in February ---
Create a query and include TblReport and TblReportDue. Include the field,
OnlyUponRequest , and set the criteria to False. Include the field,
ReportDueMonth, and set its criteria to 2. Include other fields as needed.
2. To find reports due today---
Create a query and include TblReport and TblReportDue. Include the field,
OnlyUponRequest , and set the criteria to False. Enter the following
expression in a blank field in the query:
ReportDueDate
data:image/s3,"s3://crabby-images/b34c3/b34c3adb168431b42039509bc7b19ba56d8993b5" alt="Big Grin :D :D"
ateSerial(Year(Date()),[ReportDueMonth],[ReportDueDay]) and
set the criteria to:
Date()
3. To find reports due tomorrow---
Create a query and include TblReport and TblReportDue. Include the field,
OnlyUponRequest , and set the criteria to False. Enter the following
expression in a blank field in the query:
ReportDueYear:IIF(DateSerial(Year(Date()),[ReportDueMonth],[ReportDueDay])>D
ate(),Year(Date())+1,Year(Date()))
Enter the following expression in the next blank field in the query:
ReportDueDate
data:image/s3,"s3://crabby-images/b34c3/b34c3adb168431b42039509bc7b19ba56d8993b5" alt="Big Grin :D :D"
ateSerial(ReportDueYear,[ReportDueMonth],[ReportDueDay]) and
set the criteria to:
Date() + 1
4. To find reports due in next 30 days ---
Create a query and include TblReport and TblReportDue. Include the field,
OnlyUponRequest , and set the criteria to False. Enter the following
expression in a blank field in the query:
ReportDueYear:IIF(DateSerial(Year(Date()),[ReportDueMonth],[ReportDueDay])>D
ate(),Year(Date())+1,Year(Date()))
Enter the following expression in the next blank field in the query:
ReportDueDate
data:image/s3,"s3://crabby-images/b34c3/b34c3adb168431b42039509bc7b19ba56d8993b5" alt="Big Grin :D :D"
ateSerial(ReportDueYear,[ReportDueMonth],[ReportDueDay]) and
set the criteria to:
Between Date() + 1 And Date() + 30
--
PC Datasheet
Your Resource For Help With Access, Excel And Word Applications
(e-mail address removed)
www.pcdatasheet.com
The database is for tracking the due dates of reports that we
provide to
regulatory and outside agencies (close to 400 reports annually). These
reports are due the same month/day each year so I did not want to
mess
around
with year dates, just month and day due. Occassionally, some of
the
reports
are due only when an agency requests, so we came up with 13 months, the
normal 12 and "Varies" for the 13th to cover the reports that are
due upon
request.
I have a table named Months which consists of the fields
MonthNumber (PK)
and MonthName. I created a form for data entry called Reports Database
Info.
Three fields in this table use a combo list from the MonthsQuery
to give
a
drop down menu of the months in chronological order, starting with January
and ending with Varies. The field names are MonthDue, PeriodStart
and
PeriodEnd. MonthDue is self-explanatory. PeriodStart and
PeriodEnd cover
the frequency of the report based on requirement of Monthly, Quarterly,
Semi-Annual, Annual etc. Originally, I wanted to autofill these fields
depending on first quarter (Jan-Mar) second quarter (Apr-Jun) etc
but
discovered the reports didn't always follow a specific quarter or
even
annual
- some annual are Oct thru Sept, Jan thru Dec, or July thru June
etc.
Sometimes, the months due and periods covered are based on the locations
the
reports are covering - so I was left with no uniformity to build
this on.
I
figured the easiest way was to fill in this information manually in the
three
fields - giving me the most flexibility, but pull from one table rather
than
use a date field -remember, I don't care what year it is due, just
the
month
and day.
When I go into the relationships window, it shows the three fields
are
linked one-to-many with the table named Months and are also linked
to the
query MonthsQuery (probably because of the combo box link in the
field
properties on the Data Input Form - I'm not sure). When I delete
the
MonthsQuery relationship and close the window, the relationship
re-establishes.
I'm just now creating different reports and queries to sort,
extract and
view the information in the database. Instead of displaying the
name of
the
month, the report displays the month number. The month number
doesn't
follow
my 1-13 numbering system (primary key), it follows a 0-12. On the Data
Input
Form, each record displays the month name but when I look directly into
the
table Reports Database Info, the three fields display the numbers
0 - 12 .
As I said before, your last suggestion displays the month name but only
the
names December and January, and does not follow the number logic.
I'm debating on scraping the whole primary key and just making the
information the month name only. It seems to be causing more
problems
than
it is worth.
Any suggestions?
Suzanne
:
How do you get 13 months???
Are your month numbers number data type or text? Must be number!
Do you have a textbox on your report whose controlsource is MonthName?
Did it - doesn't work right. For months numbered 0 and 1 the query
shows
December as month name - (0 = January and 1 = February - don't know
why
the
Data Input Form uses these numbers, my table uses 1 - January,
2 -
February
-- I'm stumped on this one). Months numbered 2 thru 12, query shows
January
as month name ( 2 thru 12 follows the rest of the months
chronologically
with
12 = Various - - again, don't know why it follows this format,
the
Month
table uses numbers 1 thru 13 NOT 0 thru 12).
I had set up the query to sort based on Month. Don't know if
this
affects
how the month names display in the query.
Suzanne
:
In your query leave MonthDue but add this in an empty field:
MonthName:Format([MonthDue],"mmmm")
Use the MonthName field rather than MonthDue in your report.
--
PC Datasheet
Your Resource For Help With Access, Excel And Word
Applications
(e-mail address removed)
www.pcdatasheet.com
message
Access 2000 - Set up database that pulls month name from
Month
Table
(fields
Month_Name and Month_Number). On the Data Input Form, the month
name
is
displayed for MonthDue, PeriodStart and PeriodEnd fields. When I
look
at
the
data in data view, each record displays these field with
month
name
(from
a
MonthQuery). So far, so good - the boss is very happy.
Problem - I am in the process of setting up different
queries for
different
reports, sorted in various ways. The queries and a wizard
generated
report
show MonthDue, PeriodStart and PeriodEnd with month number
not
month
name.
Want to see month name. Doesn't seem to change anything if
I
establish a
relationship or not.
I've searched Access Help, this site and any notes I've
been able
to
put
together but cannot seem to find a fix. Don't have any
books but
am
seriously contemplating Access 2000 for Dummies.