Solved

MS Access issue with "complex" expression

Posted on 2014-09-08
9
181 Views
Last Modified: 2014-09-09
This query has worked for a long time - but suddenly is throwing this error
error message
This is the query and the criteria coming from a form input
query
This is the data in the table I am querying
table data

On the form the user is entering an ending date like 08/31/14. The query had been able to translate that to 08 2014 - and the results were correct.    I don't know why I'd suddenly be getting the "too complex" error.    I reasoned that I could change my query to look at the posting-dt column instead of post-period and post-year, but I cannot since some records have a posting date that is not the same as the post-period.

I tried adding two new input field for the user to enter a post-period and post-year to use that as the criteria instead of the expression, but that did not work (returned in correct number of records).

I'd really like for this query to work as it has all along. Can an expert suggest a fix for this or point out why it may be failing?
0
Comment
Question by:Sue White
  • 3
  • 3
  • 2
  • +1
9 Comments
 
LVL 24

Expert Comment

by:chaau
ID: 40311193
I think you need to use "/" as a separator to match the Format:
CDate(Format([post-period] & "/" & [post-year], "mm/yyyy"))

Open in new window

BTW, next time please try to paste the actual code into your question instead of pictures.
0
 
LVL 24

Expert Comment

by:chaau
ID: 40311201
Having said that, I would suggest the enhancing the expression even further. It looks like you have not specified the day component of the date. I suggest you use dateSerial Access function to properly define the date from chunks:
'1st day of month
DateSerial([post-year], [post_period], 1)

Open in new window

With the help of dateAdd you can convert this date to the last date of month:
' Last Date of month: first add 1 month then subtract 1 day
DateAdd("d", -1, (DateAdd("m", 1, DateSerial([post-year], [post_period], 1)))

Open in new window

0
 
LVL 49

Expert Comment

by:Gustav Brock
ID: 40311435
First, use this expression to create your date as the first day of the period directly:

    DateSerial([post-year], [post_period], 1)

Then, add your form reference as a parameter in the query. Specify data type Date. This is the key to solve your issue:

    [Forms]![frmMiscellaneousTab]![frmMiscellaneousAcct]![EndingDate]

or as:

    [Forms]![frmMiscellaneousTab]![frmMiscellaneousAcct].Form![EndingDate]

/gustav
0
 

Author Comment

by:Sue White
ID: 40312678
Thank you both for your replies.  I did not author this query, so I cannot claim to fully understand it why it was created as it is.   The goal is for the query to generate results where the ending date the user enters is less than or equal to the values in the columns post-period and post-year.    I understand this is trying to concatenate the post-period and post-year into a date format (CDate(Format(([post-period] & "  " & [post-year]),"mm/yyyy")))  - and I see the value in chaau's suggestion to make this:
(CDate(Format(([post-period] & "/" & [post-year]),"mm/yyyy")))

I created a new simple query to see what results I get from:

SELECT DateSerial([post-year],[post-period],1) AS SerialFunc, (CDate(Format(([post-period] & "/" & [post-year]),"mm/yyyy"))) AS CDateFunc

and they both produce the same results
Expression Results
That's good, but I don't understand how I use that to filter the results from the table if the user enters 8/31/14 as the ending date and it needs for find all the records where the post-period & post-date are less than or equal to 8/31/14,

why or how I would use DateAdd function or Gustav's comment to specify the data type of Date.
0
Ransomware-A Revenue Bonanza for Service Providers

Ransomware – malware that gets on your customers’ computers, encrypts their data, and extorts a hefty ransom for the decryption keys – is a surging new threat.  The purpose of this eBook is to educate the reader about ransomware attacks.

 
LVL 31

Expert Comment

by:Helen_Feddema
ID: 40313007
How about this:  
Test Query
0
 
LVL 49

Accepted Solution

by:
Gustav Brock earned 500 total points
ID: 40313024
DateSerial is the function to use when you have the separate year, month, and day parts. Other methods can be used but will be more convoluted.

If you need to filter on records earlier than the last date of the period, again DateSerial is the direct method:

Use this expression to create your date as the last day of the period directly:

     DateSerial([post-year], [post_period] + 1, 0)

Note the subtle use of zero for the day.
Then, add your form reference as a parameter in the query. Specify data type Date. This is the key to solve your issue (the error message):

     [Forms]![frmMiscellaneousTab]![frmMiscellaneousAcct]![EndingDate]

 or as:

     [Forms]![frmMiscellaneousTab]![frmMiscellaneousAcct].Form![EndingDate]

 /gustav
0
 

Author Comment

by:Sue White
ID: 40313055
Ah I see Gustav - yes that does work!
Helen - I did initially try a query as you were suggesting but I ended up with an incorrect number of records.  My real query is using grouping and some other expressions that I didn't include in this ticket for simplicities sake.  I knew the issue was with the CDate() function.  

Thank you to all the experts that replied - I apprecriate your guidance.
0
 

Author Closing Comment

by:Sue White
ID: 40313058
I appreciate the explanation given!
0
 
LVL 49

Expert Comment

by:Gustav Brock
ID: 40313064
You are welcome!

/gustav
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article is a continuation or rather an extension from Cascading Combos (http://www.experts-exchange.com/A_5949.html) and builds on examples developed in detail there. It should be understandable alone, but I recommend reading the previous artic…
Describes a method of obtaining an object variable to an already running instance of Microsoft Access so that it can be controlled via automation.
With Microsoft Access, learn how to specify relationships between tables and set various options on the relationship. Add the tables: Create the relationship: Decide if you’re going to set referential integrity: Decide if you want cascade upda…
In Microsoft Access, when working with VBA, learn some techniques for writing readable and easily maintained code.

911 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

26 Experts available now in Live!

Get 1:1 Help Now