Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Is there a way to do the equivalent of Excel's Sumifs() in an Access Expression (or VBA)

Posted on 2010-11-26
9
Medium Priority
?
2,009 Views
Last Modified: 2012-05-10

I have a table in Access with information (see attached).  I'm trying to figure out if there is a way to get the sum of a column (field) where a certain criteria in two other fields is met.  For example, I'd like to get year to date (YTD) totals for a given account.  So, I'd need the total sales for a given account (criteria #1) for all months between Jan. and the current records Month.  Does anyone know if there is a way to do this in Access?
Sumifs-AccessEquivalent.xlsx
0
Comment
Question by:BBlu
  • 5
  • 2
  • 2
9 Comments
 
LVL 44

Accepted Solution

by:
GRayL earned 800 total points
ID: 34220335
This do it?

SELECT Sum([Field] from myTable WHERE Year(AcctDate) = Year(Date()) AND AcctNo = [Enter Acct No];
0
 

Author Comment

by:BBlu
ID: 34220346
Probably pretty close, but I'd like they date criteria to be for any date on or before the date of the current record.  How would that change the code? Also, that is a SQL statement.  Is there an expression that I could use in a a query to add a field with that data?
0
 
LVL 12

Expert Comment

by:Missus Miss_Sellaneus
ID: 34220352
you need something like this..

SELECT acct, SUM(IIF(Month >= january AND Month <= currentmonth, Sales, 0)) AS YTDSales
 FROM table1
 HAVING YTDSales <> 0



0
Get free NFR key for Veeam Availability Suite 9.5

Veeam is happy to provide a free NFR license (1 year, 2 sockets) to all certified IT Pros. The license allows for the non-production use of Veeam Availability Suite v9.5 in your home lab, without any feature limitations. It works for both VMware and Hyper-V environments

 

Author Comment

by:BBlu
ID: 34220364
Thank you very much.  But that would be the sql for a query, right?  Is there a way to do it in an expression.
0
 
LVL 12

Assisted Solution

by:Missus Miss_Sellaneus
Missus Miss_Sellaneus earned 800 total points
ID: 34220377
Maybe I got a little too fixated on the IIF part of your question.

Do you want to see only those rows that had sales during the given date range? If so, you only need to use a WHERE clause like GRavL showed you.

If you want to include customer records that may not have sales in that date range, you'll need the SUM/IIF.

Do you want to prompt the user for the date range?
0
 

Author Comment

by:BBlu
ID: 34220392
I'm actually trying to reproduce an excel file our sales team has been manually doing for years.  We have all of the data in two access tables.  For each account we have a matrix with columns for all months in the current period.  We then have rows for Sales, YTD sales, Payments, YTD Payments.  (If I can figure out one, I can do both; that's why I didn't mention the pmts. part).  Anyhow, I was thinking I could mimic the excel file by:

1. creating a query and adding a field/column for the YTD total for each record.  For example, if the record has:
a. Account= 1234
b. Month=3/1/10 (March 2010)
c. Sales= $340
I could add a field
d. YTDSales = $640 (if Jan was $200 and Feb was $100, for example)

2. I could then do a Union Query something like
Select "Sales" as Category, Account, Month, Sales from SalesTable
Union All
Select "YTD" as Category, Account, Month, YTDSales from SalesQuery

And if I I had a table that ordered the 'Category' Field, I could reproduce what I'm going after (see attached)
DesiredReport.xlsx
0
 

Author Comment

by:BBlu
ID: 34220494
I almost figured it out..I guess the real question is:
Is there a way to have multiple criteria in DSum?

DSum("UnitPrice", "Order Details", "OrderID = 10248")
0
 

Author Comment

by:BBlu
ID: 34220542
I figured out that you can use "AND" to add multiple criteria.  But I did not know how to do it in SQL either, so you helped.  Thanks.
0
 
LVL 44

Expert Comment

by:GRayL
ID: 34222919
Thanks, glad to help.
0

Featured Post

Efficient way to get backups off site to Azure

This user guide provides instructions on how to deploy and configure both a StoneFly Scale Out NAS Enterprise Cloud Drive virtual machine and Veeam Cloud Connect in the Microsoft Azure Cloud.

Question has a verified solution.

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

Code that checks the QuickBooks schema table for non-updateable fields and then disables those controls on a form so users don't try to update them.
Explore the ways to Unlock VBA Project Password Excel 2010 & 2013 documents. Go through the article and perform the steps carefully to remove VBA Excel .xls file.
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…
Look below the covers at a subform control , and the form that is inside it. Explore properties and see how easy it is to aggregate, get statistics, and synchronize results for your data. A Microsoft Access subform is used to show relevant calcul…
Suggested Courses

927 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