Mysql/Java根据出生日期计算年龄

Mysql 根据出生日期计算年龄
1.DATEDIFF()计算天数差,一年365天5小时48分46秒(365.2422天),FLOOR()向下取整
SELECT name,birth,FLOOR(DATEDIFF(CURDATE(),birth)/365.2422) AS age FROM sys_user
  
2.DATEDIFF()计算天数差,FROM_DAYS()将天数转换为日期格式
SELECT name,birth,YEAR(FROM_DAYS(DATEDIFF(CURDATE(),birth))) AS age FROM sys_user
  
3.看着稍微复杂点,仔细看就是当前日期年相差,月份比较
SELECT name,birth,
(YEAR(CURDATE())-YEAR(birth)-1) + (DATE_FORMAT(birth,'%m%d') <= DATE_FORMAT(CURDATE(),'%m%d')) AS age
FROM sys_user

比较年比较月份,可以得到几周岁又几个月

SELECT name,CONCAT(age1, month1) age FROM (
SELECT name,CONCAT(TIMESTAMPDIFF(YEAR,entry_date,CURDATE()),"周岁") as age1,
			CONCAT(MOD(TIMESTAMPDIFF(MONTH,entry_date,CURDATE()),12),"月") as month1 
FROM sys_contract WHERE id = '1' 
) as a

  
4.TIMESTAMPDIFF()函数,这个是目前最精简的
SELECT name,birth,TIMESTAMPDIFF(YEAR,birth,CURDATE()) AS age FROM sys_user
Java 根据出生日期计算年龄
/**
 * 根据出生年月计算年龄
 * @param birth
 * @return age
 */
public static String getAgeByBirth(String birth){
   if ("".equals(birth.trim()) || birth.trim() == null) {
      return null;
   }
   //此处调用了获取当前日期,以yyyy-MM-dd格式返回的日期字符串方法
   String nowDate = DateUtils.getDate();
   int age = Integer.parseInt(nowDate.substring(0, 4))- Integer.parseInt(birth.substring(0,4));
   return Integer.toString(age);
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值