Solved

How to calculate age from birthdate in SSRS

Posted on 2014-03-13
8
3,771 Views
Last Modified: 2014-03-13
Hello Experts,

I'm using Report Builder 3.0 and have a dataset which has birth dates of users (mm/dd/yyyy).  I've added a table to my report showing some basic data of users per row and added an Age column.  

Can anyone help me to calculate the age per user and populate their age in the new column?  I've tried some expressions, with no luck.  This is the last expression I tried:
=DATEDIFF(DateofBirth, getDate())

Open in new window

Screenshot for Report Builder Age CalculationExtra Info:
SQL Server Reporting Services 2008 R2
Report Builder 3.0

Any help is much appreciated, thank you.
0
Comment
Question by:Modifier1000
  • 4
  • 4
8 Comments
 

Author Comment

by:Modifier1000
ID: 39926394
Well, I got this far:
=DateDiff("yyyy", Fields!DateofBirth.Value, Now())

Open in new window


It gives me the year, but it rounds up, now I just need to get year and month for a more exact date.  Also, any users without a birthdate entered, the Age value is 2013.  So I have about 20 users where someone did not enter their birthdate and their age shows 2013.Age is 2013 for users w/o birthdates entered
0
 
LVL 26

Expert Comment

by:Zberteoc
ID: 39926675
Use:

DATEDIFF(YY,DateofBirth, getDate())
0
 

Author Comment

by:Modifier1000
ID: 39926761
You suggest that for the Expression of a field in Report Builder (SSRS)?
0
Resolve Critical IT Incidents Fast

If your data, services or processes become compromised, your organization can suffer damage in just minutes and how fast you communicate during a major IT incident is everything. Learn how to immediately identify incidents & best practices to resolve them quickly and effectively.

 
LVL 26

Expert Comment

by:Zberteoc
ID: 39926816
That is the SQL syntax and I saw you tried it but wrongly.
0
 
LVL 26

Accepted Solution

by:
Zberteoc earned 500 total points
ID: 39926829
To avoid the "rounding" issue You can try with months instead of years in you report formula, which I would now from the top of my head. Something like:

 DateDiff("mm", Fields!DateofBirth.Value, Now())/12
0
 

Author Comment

by:Modifier1000
ID: 39926891
Ahhh, ok.

Well, I used your above expression and did a little massaging to get the following expression, which works:
=Round((DateDiff("m", Fields!DateofBirth.Value, Now()))/12, 1)

Open in new window


Now I just need to figure out how to remove 2013 values from the Age column w/o an entered birthdate.

Thank you for pointing me in the right direction!
0
 

Author Closing Comment

by:Modifier1000
ID: 39926892
Thanks!
0
 
LVL 26

Expert Comment

by:Zberteoc
ID: 39926935
In order to get rid of that 2013 you need to replace the NULL values with Now(). I am not sure what is the syntax in SSRS but someting like:

Round((DateDiff("m", IfEmpty(Fields!DateofBirth.Value,Now()), Now()))/12, 1)

and the age in that case will return 0.
0

Featured Post

Resolve Critical IT Incidents Fast

If your data, services or processes become compromised, your organization can suffer damage in just minutes and how fast you communicate during a major IT incident is everything. Learn how to immediately identify incidents & best practices to resolve them quickly and effectively.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
MS SSRS scale out 13 70
Locating SQL Data Tools 2012 11 43
Crystal Report Grand Total in Main Report from Sub Reports 6 76
sql query to reportserver  table error 3 51
Introduction In the following article I’ll be discussing and demonstrating several different ways of how images can be put on a report. I’m using SQL Server Reporting Services 2008 R2 CTP, more precisely version 10.50.1352.12, but the methods ex…
It is helpful to note: This is a cosmetic update and is not required, but should help your reports look better for your boss.  This issue has manifested itself in SSRS version 3.0 is where I have seen this behavior in.  And this behavior is only see…
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…
In an interesting question (https://www.experts-exchange.com/questions/29008360/) here at Experts Exchange, a member asked how to split a single image into multiple images. The primary usage for this is to place many photographs on a flatbed scanner…

860 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