Solved

How to calculate age from birthdate in SSRS

Posted on 2014-03-13
8
3,655 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
3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

 
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

3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
SSRS UK Map with Postcodes 2 124
SSRS displaying blank space between rows 6 28
Please help| Getting the syntax error in below query. 2 56
Install SSRS for developer 1 25
Hi All, I am here to write a simple article to move SSRS (SQL Server Reporting Services) reports from one server to another. When I have faced the same issue to move reports those were developed by developer on development server and now need to …
Introduction Earlier I wrote an article about the new lookup functions (http://www.experts-exchange.com/A_3433.html) that ship with SQL Server 2008 R2.  In this article I’m going to show you another new feature of SSRS 2008 R2, this time in the vis…
This Micro Tutorial will teach you how to censor certain areas of your screen. The example in this video will show a little boy's face being blurred. This will be demonstrated using Adobe Premiere Pro CS6.
This is used to tweak the memory usage for your computer, it is used for servers more so than workstations but just be careful editing registry settings as it may cause irreversible results. I hold no responsibility for anything you do to the regist…

813 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

12 Experts available now in Live!

Get 1:1 Help Now