SQL语句如何根据出生日期计算年龄

发布网友

我来回答

7个回答

懂视网

select trunc(months_between(sysdate,date‘1992-12-8‘)/12)  年龄 from dual;

技术分享

用到两个函数:trunc和months_between

trunc函数两种用法:

1、trunc(number1,number2),只舍不入取值。

number1:原始数据,要操作的对象

number2:操作要求

number2>0,保留到小数点右边第number2位.

number2<0,将小数点左边第number2位舍去。

number2=0或者没有number2参数,是只保留到整数。

例:trunc(5.75698,2),结果:5.75

      trunc(17.23,-2),结果:1700

      trunc(5.75,0)或者trunc(5.75),结果:5

2、trunc(date,month/year),将date截取到年或者月。

例:trunc(date‘2014-7-16‘,‘month‘)  结果:2014/7/1

      trunc(date‘2014-7-16‘,‘year‘) 结果:2014/1/1

months_between函数

months_between(x,y),计算x-y,结果是相差的月份数。

例子:months_between(sysdate,date‘1996-12-8‘)  结果:225.824334677419---表示相差的月份数

 

     

SQL语句计算周岁

标签:

热心网友

第一种:
一张人员信息表里有一人生日(Birthday)列,跟据这个列,算出该人员的年龄
datediff(year,birthday,getdate())
例:birthday = '2003-3-8'
getDate()= '2008-7-7'
结果为:5
这样结果是会返回该人员的大概年龄,但不精确.不会精确到月或日.
按照上面测试的日期,该人员的实际年龄应该还不满5岁。在需要精确年龄的时候,就会有错.
第二种:
FLOOR(datediff(DY,birthday,getdate())/365.25)
FLOOR函数:
FLOOR(expr) 返回小于或等于expr的最大整数.FLOOR(1.1)返回1,FLOOR(-1.1)返回-2,FLOOR(1)返回1
这样就可以精确算出,该人员当前实际年龄了.
测试:
birthday = '2000-7-8'
getdate()= '2007-7-7'
算出结果为:6

在Oracle中,要获得日期中的年份,例如把sysdate中的年份取出来。
一种常用的方法是:to_number(to_char(sysdate,'yyyy'))
还有一种更好的方法,那就是使用oracle提供的Extract函数,使用方法是:
extract(year from sysdate) ,此方法获得的结果是数值型的 ,这种方法省掉了类型转换,更加简洁。
相应的,要取得月份或日,可以用extract (month from sysdate) 和extract (day from sysdate)

热心网友

1、计算年龄其实就是计算当前日期和出生日期之间的差值

2、SQL计算时间差值使用的函数是:Datediff()

    定义和用法:

    DATEDIFF() 函数返回两个日期之间的天数。

    语法:

    DATEDIFF(datepart,startdate,enddate)

    startdate 和 enddate 参数是合法的日期表达式。

    datepart 参数可以是下列的值:

    datepart--缩写

    年--yy或yyyy

    季度--qq或q

    月--mm或m

    年中的日--dy或y

    日--dd或d

    周--wk或ww

    星期--dw或w

    小时--hh

    分钟--mi或n

    秒--ss或s

    毫秒--ms

    微妙--mcs

    纳秒--ns

    示例:

SELECT DATEDIFF(day,'2008-12-29','2008-12-30') AS DiffDate

    结果:

DiffDate
1

3、那么依据出生日期计算年龄就可以这么写(假设表名为table_1,出生日期列为:BirthDate_col):

select 
    datediff(yy,BirthDate_col,getdate()) as 周岁
    ,(datediff(yy,BirthDate_col,getdate())+1) as 虚岁
from 
    table_1

热心网友

出生日期求出来了是吧,求当前时间与生日时间相差多少个月,再除12就可以了,问下你用的是oracle,还是sql server,如果是oracle如下样例,sql server应该也有类似的函数,除12后根据需要是取整还是四舍五入。

select months_between(sysdate,date'1986-12-7')/12 from al;

热心网友

使用datediff函数
select datediff(year,'1988.1.1',getdate())
这是计算1988年出生人的年龄

热心网友

SELECT CAST( DATEDIFF(CURRENT_DATE(),'1988-08-09') /365 AS SIGNED )
FROM DUAL;

热心网友

是算不出来的啊

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com