Oracle Age calculation from Date of birth and Today(从出生日期和今天计算 Oracle 年龄)
本文介绍了从出生日期和今天计算 Oracle 年龄的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想在我的 Oracle 函数中从出生日期计算当前年龄.
I want to calculate the current Age from Date of Birth in my Oracle function.
我使用的是 (Today-Dob)/30/12
,但这并不准确,因为有些月份有 31 天.
What I am using is (Today-Dob)/30/12
, but this is not accurate as some months have 31 days.
我需要以最大的精度获得正确的年龄.我怎样才能做到这一点?
I need to get the correct age with the maximum precision. How can I do that?
推荐答案
SQL> select trunc(months_between(sysdate,dob)/12) year,
2 trunc(mod(months_between(sysdate,dob),12)) month,
3 trunc(sysdate-add_months(dob,trunc(months_between(sysdate,dob)/12)*12+trunc(mod(months_between(sysdate,dob),12)))) day
4 from (Select to_date('15122000','DDMMYYYY') dob from dual);
YEAR MONTH DAY
---------- ---------- ----------
9 5 26
SQL>
这篇关于从出生日期和今天计算 Oracle 年龄的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:从出生日期和今天计算 Oracle 年龄


基础教程推荐
猜你喜欢
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- oracle区分大小写的原因? 2021-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- 在多列上分布任意行 2021-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01