当前位置:首页 » 编程语言 » sql年龄
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql年龄

发布时间: 2022-01-26 05:15:59

sql求年龄

你这是oralce吧
--获取两时间年份差
select EXTRACT(year FROM to_date('2009-05-01','yyyy-mm-dd')) - EXTRACT(year FROM to_date('2008-04-30','yyyy-mm-dd')) years from al;
如果是sql
那就简单了

⑵ sql求平均年龄

select class,avg(year(getdate())-year(birth))
from students
where class='05313'
group by class

没必要再用子查询,使用聚合函数前要使用group by

⑶ sql 查询每个年龄的人数

select COUNT(*) as 每个年龄的人数,年龄 from 员工表 group by 年龄

⑷ sql中定义年龄用什么数据类型,长度为多少

sql中定义年龄可以用的用数据类型及长度:

1、char(3):长度为3的字符串。小于10位且长度基本固定的字符串用char。

2、varchar(3):长度为3的字符串。长度大于10的用varchar,varcha在10以内占用空间比char大。

3、int:长度为4个字节,存储从(-2147483648)到(2147483647)。

4、Smallint:长度为2个字节,存储从-32768到32767。

5、tinyint:长度为1个字节,存储0到255的数字。

(4)sql年龄扩展阅读:

sql函数

UCASE(c)将某个域转换为大写

LCASE(c)将某个域转换为小写

MID(c,start[,end])从某个文本域提取字符

LEN(c)返回某个文本域的长度

INSTR(c,char)返回在某个文本域中指定字符的数值位置

LEFT(c,number_of_char)返回某个被请求的文本域的左侧部分

ROUND(c,decimals)对某个数值域进行指定小数位数的四舍五入

⑸ 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)

⑹ 关于一个sql语句书写 查询年龄的

不知道你具体用的什么数据库


给你sqlserver的写法吧


selectA,B
from表
whereDATEDIFF(dd,b,getdate())*1.0/365between10and30

大概就是这样,我是用天计算的,各个数据库有差别,,,,

⑺ SQL中,如何查询年龄

日期函数,access与SQL Server是有一点区别的,
如果是access的话,
select * from 你的表名
where year(now())-year(出生日期) between 20 and 25
如果是SQL Server的话,
select * from 你的表名
where year(getdate())-year(出生日期) between 20 and 25
呵呵,希望能有帮助,^_^

⑻ SQL计算年龄

你好 你的问题不需要增加员工年龄这列

因为随着一年一年的时间,年龄是动态计算的

通常用 系统时间-出生日期 显示出来就可以了
Oracle
select round((sysdate - to_date('2008-01-01','YYYY-MM-DD'))/365,0)
from al
;
SQL查询一下联机帮助文档

⑼ sql 计算年龄

用getdate()获得今天的日期,再用datediff算的年数
也可以直接取年份相减啊

⑽ SQL统计年龄段

例如:
select case when [年龄] BETWEEN 10 AND 20 then '10-20'
when [年龄] BETWEEN 20 AND 30 then '20-30'
when [年龄] > 30 then '30以上' end as '年龄段',
count(*) as '人数' FROM [Table]