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

sql年龄如何返回数值型

发布时间: 2022-08-04 01:05:01

1. 如何用sql语句把出生日期计算年龄,比如是1984-2-16怎么算出年龄啊

语句为:SELECT FLOOR(DATEDIFF(CURRENT_DATE,'1984-2-16')/356)

常用sql对数据库操作:

  1. 连接数据库命令:mysql -u root -p密码

  2. 创建数据库:create database dbname;

  3. 查看所有的数据库:show databases;

  4. 删除数据库:drop database dbname;

  5. 切换数据库:use dbname;


知识拓展:

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于Oracle旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。

2. 在SQL语句里面如何将字符型转换成数字型

将字符的数字转成数字,比如'0'转成0可以直接用加法来实现;

例如:将pony表中的d 进行排序,可d的定义为varchar,可以这样解决;

select * from pony order by (d+0);

在进行ifnull处理时,比如 ifnull(a/b,'0') 这样就会导致 a/b成了字符串,因此需要把'0'改成0,即可解决此困扰;

比较数字和varchar时,比如a=11,b="11ddddd";

则 select 11="11ddddd"相等;

若绝对比较可以这样:

select binary 11 =binary "11ddddd";

字符集转换 : CONVERT(xxx USING gb2312);

类型转换和SQL Server一样,就是类型参数有点点不同 : CAST(xxx AS 类型),CONVERT(xxx,类型);

类型必须用下列的类型:BINARY、CHAR()、DATE、TIME、DATETIME、DECIMAL、SIGNED、UNSIGNED。

3. 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)

4. 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)对某个数值域进行指定小数位数的四舍五入

5. sql 中怎样把字符型转换成数值型

val()

比如 val(“10”)=10

6. 将SQL语句查询出来的值转换为数字类型

ANSI规定,在一个表达式中如果有null值,则表达式返回null,
如:1+2+3+null,我们本希望它等于6,结果却等于null,
解决方法就是用isnull()函数来剔除null值,
如:1+2+3+isnull(变量名,0);

但是,如果表达式中使用了聚合函数,比如sum()函数,则不需要这样转换,因为sum()函数会自动剔除null值,
比如以下的语句可以得出正确的值,尽管字段中有null值.
select 1+2+3+sum(字段名) from table.

7. sql 怎么把日期类型的数据转换成数字类型

用cast函数来进行转换。先利用cast函数将数字型转为字符型,再用一次cast函数将字符型转为日期型。

8. SQL中where 年龄='任意值',年龄字段等于任意值怎么表达实现格式一定要where 年龄=

where 年龄=年龄

用参数的写法:

WHERE
年龄 = CASE WHEN 参数 = '任意值' THEN 年龄 ELSE 参数 END

这样当 传入的参数为 '任意值' 的时候, 条件为 年龄=年龄
传入的参数为 25 的时候, 条件为 年龄=25

不过由于 数据类型的问题, 年龄是 数字型的, 那个 '任意值' 是字符型的
CASE WHEN 参数 = '任意值' THEN 年龄 ELSE 参数 END
可能会出错

一般是
CASE WHEN 参数 IS NULL THEN 年龄 ELSE 参数 END
这种情况下,如果参数不传,就是全部。

9. 在sql数据库里面知道所有学生的年龄,如何返回出生年份

select datepart(yyyy,getdate())-年龄