Solved

Help understanding IFF(

Posted on 2011-09-12
5
388 Views
Last Modified: 2012-05-12
Experts,
I'm trying to understand a query I've inherited that encompasses IFF( as seen below:

IIf([check amount] Between 60 And 80,9,IIf([check amount] Between 80 And 100,12,IIf([check amount] Between 100 And 120,15,IIf([check amount] Between 120 And 140,18,IIf([check amount] Between 140 And 160,21,IIf([check amount] Between 160 And 180,27,IIf([check amount] Between 180 And 200,30,IIf([check amount]>200,30,0)))))))) AS [held fee]

Can somebody please explain in English what's going on here?
0
Comment
Question by:Frank Freese
5 Comments
 
LVL 33

Accepted Solution

by:
Norie earned 250 total points
ID: 36524323
This is the basic logic with the input value ([check amount]) on the left and the output ([Held Fee]) on the right.

Check Amount     Held Fee
60-80                      9
80-100                    12
100-120                  15
120-140                  18
140-160                  21
160-180                  27
180-120                  30
>200                      30

Or is it the whole syntax of the Iif you want explained?
0
 
LVL 47

Assisted Solution

by:Dale Fye (Access MVP)
Dale Fye (Access MVP) earned 250 total points
ID: 36524339
Nested IIF statements can be confusing.  This is the same as:


If [check amount] Between 60 And 80 Then
    Held Fee = 9
elseif [check amount] Between 80 And 100 then
    Held Fee = 12
Elseif [check amount] Between 100 And 120 then
    Held Fee = 15
Elseif [check amount] Between 120 And 140 then
    Held Fee = 18
Elseif [check amount] Between 140 And 160 then
    Held Fee = 21
Elseif [check amount] Between 160 And 180 Then
    Held Fee = 27
Elseif [check amount] Between 180 And 200 Then
    Held Fee = 30
Elseif [check amount]>200 then
    Held Fee = 30
Else
    Held Fee = 0
End If

Of course you cannot use BETWEEN like this in vba code, but you get the idea.  Personally, I prefer to use the Switch function.  In your query, it would look like:

SWITCH([check amount] < 60, 0, [check amount] < 80, 9, [check amount]< 100, 12, [check amount] < 120, 15, [check amount] < 140, 18, [check amount] < 160, 21, [check amount]<180, 27, [check amount] >= 180, 30, True, 0)

which is a little easier to read, and because the criteria are evaluated in order, you don't need to include the lower limit in the equation.
0
 
LVL 119

Expert Comment

by:Rey Obrero
ID: 36524346
the first IIF
IIf([check amount] Between 60 And 80,9  
   * is testing the value of [Check AMount] is in the range of 60 to 80 and to return a value of 9

   * if the value is not satisfied by the first condition ( range of 60 to 80 ) it test the next
IIf([check amount] Between 80 And 100,12

and so on,

and if nothing in the IIF expression was satisfied , return a value of 0


*NOTE

you have an overlapping ranges of values

Between 60 And 80

Between 80 And 100


that should written like this

Between 60 And 79

Between 80 And 99

Between 100 And 119        

and so on


0
 

Author Closing Comment

by:Frank Freese
ID: 36524353
thanks - I noticed the overlapping values - these developers just did such a poor job
0
 
LVL 33

Expert Comment

by:Norie
ID: 36524478
By the way, you could probably cut the expression down.

I tried a few things but the 'blip' from 21 to 27 throws it off.
0

Featured Post

U.S. Department of Agriculture and Acronis Access

With the new era of mobile computing, smartphones and tablets, wireless communications and cloud services, the USDA sought to take advantage of a mobilized workforce and the blurring lines between personal and corporate computing resources.

Question has a verified solution.

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

In Debugging – Part 1, you learned the basics of the debugging process. You learned how to avoid bugs, as well as how to utilize the Immediate window in the debugging process. This article takes things to the next level by showing you how you can us…
QuickBooks® has a great invoice interface that we were happy with for a while but that changed in 2001 through no fault of Intuit®. Our industry's unit names are dictated by RUS: the Rural Utilities Services division of USDA. Contracts contain un…
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Polish reports in Access so they look terrific. Take yourself to another level. Equations, Back Color, Alternate Back Color. Write easy VBA Code. Tighten space to use less pages. Launch report from a menu, considering criteria only when it is filled…

863 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

24 Experts available now in Live!

Get 1:1 Help Now