Excel Database Functions
There is a database function for nearly every aggregation type, from average through to variance, as listed below. They're an alternative to SUMIFS, AVERAGEIFS, MINIFS etc. except more powerful.
Function | Description |
DAVERAGE | Returns the average of selected database entries |
DCOUNT | Counts the cells that contain numbers in a database |
DCOUNTA | Counts nonblank cells in a database |
DGET | Extracts from a database a single record that matches the specified criteria |
DMAX | Returns the maximum value from selected database entries |
DMIN | Returns the minimum value from selected database entries |
DPRODUCT | Multiplies the values in a particular field of records that match the criteria in a database |
DSTDEV | Estimates the standard deviation based on a sample of selected database entries |
DSTDEVP | Calculates the standard deviation based on the entire population of selected database entries |
DSUM | Adds the numbers in the field column of records in the database that match the criteria |
DVAR | Estimates variance based on a sample from selected database entries |
DVARP | Calculates variance based on the entire population of selected database entries |
Database Function Example 1 - How DSUM Works
DSUM syntax
=DSUM(database, field, criteria)
Taking the data below stored in an Excel Table called 'DataTable',
let’s say I want to SUM the amounts for all Level 1 invoices:
data:image/s3,"s3://crabby-images/4f907/4f907029fedb0d882c3f608bdd9832ba827f5dfa" alt="excel dsum"
The second argument for DSUM is the criteria.
This is stored in cells in the workbook (on any sheet):
data:image/s3,"s3://crabby-images/2d077/2d077c78eef1893e138f719c622b69a7658ad050" alt="excel dsum"
And the formula would be written:
=DSUM(DataTable[#All],"Amount",$G$6:$G$7)
data:image/s3,"s3://crabby-images/5f449/5f4491e5cd1d9241827cf74dbebde1bf4bb819d8" alt="excel dsum"
Syntax Notes:
= DataTable[#All]. This is a Table Structured
Reference for my tabular data set including the column labels, hence [#ALL] in the reference. Alternatively, I could type in the cell range A4:E70 (including column labels).
= "Amount".
This is the name of the column I want to sum. This could also be the column number of the data table, in this example, 5.
= $G$6:$G$7. This is the range of the criteria table
Database Function
Example 2 - Multiple AND Criteria
Let’s say I want to SUM all Level 1 invoices for the period January – March 2021. When working with 'AND' criteria, they go across the columns in a single row like this:
data:image/s3,"s3://crabby-images/130b9/130b968ac5f8dc8cb16f675afa1eac134e544542" alt="dsum"
Note: my dates are dd/mm/yyyy. Please change the dates in the criteria table to suit your Excel region settings.
Then my database formula is:
=DSUM(DataTable[#All],"Amount",$A$5:$C$6)
Result = $38,000 which represents the sum of the amount column in my table for Level 1 for the period January to March 2021.
Database Function Example 3 - Multiple AND OR Criteria
Ok,
what if I wanted to SUM both Level 1 AND where dates are between January AND March, OR for Level 2 where dates are between January AND March?
Easy, add another line to your criteria table like this:
data:image/s3,"s3://crabby-images/0894d/0894d7b5d1fbe938143aaa07ca8b188a21d9c12f" alt="excel database function"
Remember to also update your DSUM formula to include the new row of criteria:
=DSUM(data_table,"Amount",$A$5:$C$7)
Result = $229,151 which is summing Level 1 and Level 2 amounts that are in the date range January – March 2021.
But wait, there’s more. Database functions aren’t limited to SUM. You can AVERAGE, COUNT, COUNTA, MAX, MIN and more.
They all use the same syntax, and they can all use the same criteria table.
=DCOUNT(data_table,"Amount",$A$5:$C$7)
Result: 15
=DAVERAGE(data_table,"Amount",$A$5:$C$7)
Result: $15,277
=DMAX(data_table,"Amount",$A$5:$C$7)
Result: $34,970
=DMIN(data_table,"Amount",$A$5:$C$7)
Result: $1000
You don’t even need to remember complicated acronyms for these functions. Just add a ‘D’ to the front of the function you want.
Database
Function Example 4 - Multiple OR criteria, same field
data:image/s3,"s3://crabby-images/dbae9/dbae976571ca490d758d53cdfd1856e24d3f140f" alt="excel database functions multiple or criteria"
The takeaway here is 'OR' criteria are listed down the rows,
whereas 'AND' criteria are listed across the columns of a single row.
Database Function Example 5 - Multiple OR criteria, different field
data:image/s3,"s3://crabby-images/55ad3/55ad3305c88a6f6b2f738fdca09819e0367d3f56" alt="excel database function different field or criteria"
This criteria will aggregate all data which is level 1, including level 1 for Atkins (because the name field is blank on the first criteria row), plus all other levels except those that are for Atkins (because the Type field is blank on the second criteria row).
Database Function Example 6 - Wildcards
Database functions can also handle
wildcards. Here I want to aggregate all data where the names begin with B.
data:image/s3,"s3://crabby-images/3c3bf/3c3bfcc8c5dec0640628701e2d89985cacb47f76" alt="excel database function wildcards"
Notice this
time I used the column number in the field argument instead of the column name.
Database Function Example 7 - DGET Function
Unlike the other database functions which aggregate data, the DGET function only returns a single value. If your result returns more than one matching record you'll get the #NUM! error.
data:image/s3,"s3://crabby-images/74b8e/74b8e54d5a53288cbcdcd25a301b8c125fc52544" alt="DGET function"
Excel Database Function Rules
- Your criteria table only needs columns for the data you want to filter on. So, if your tabular data set has hundreds of columns, don’t panic. You don’t need every column replicated
again in your criteria table.
- You can add multiple 'OR' criteria by adding them to a new row in your criteria table.
- If your Database formula includes criteria rows that are blank then it will sum/average/count etc. the whole table. Essentially ignoring your criteria altogether.
- The
criteria table can house formulas e.g. links to other cells, drop down lists and the like, so get creative with how you use them to incorporate interactivity into your reports.
- The Criteria table is not case sensitive, not for the column
labels or the criteria itself.
- The ‘Field’ part of the formula can be the column name or the column number.
The Downside of Excel Database Functions
The obvious downside is that the Database Functions require a bit more worksheet real estate to house the criteria as opposed to an array formula and the like, but with over 1 million
rows I think we can afford it.
I think the upsides, like the fact that you can see exactly what the criteria is in plain English and how easy they are to use far outweighs the downside.
Next Steps
If you’re finding these Excel functions useful, and you want to take your skills even further, check
out my Advanced Excel Formulas course. It's packed with all the functions that will save you hours of work and help you stand out.
What’s great about this course is that it doesn’t just cover the
basics—it dives into real-world examples with quick, bite-sized videos, showing you both the fundamentals and more advanced, less obvious uses of functions.
Once you’re done, you’ll have a solid understanding of how to create robust formulas that enable you to handle any scenario.