1.前言
在设计数据表时,由于用户的年龄每年都会发生改变,因此,不推荐使用age直接存储用户年龄。
推荐的做法为:存储用户的生日,在需要使用用户年龄时,通过当前的时间和生日之间的差值进行年龄计算。
2.java实现
使用java实现年龄计算的代码如下:
/**
* 根据用户编号获取详细信息
*/
@GetMapping(value = {"/query/{id}"})
public AjaxResult getInfo(@PathVariable(value = "id") Integer id)
{
AjaxResult ajax = AjaxResult.success();
User user = userService.selectUserById(id);
// 获取当前日期
LocalDate currentDate = LocalDate.now();
// 获取用户的生日(年-月-日格式)
String birthDateString = user.getBirthday();
// 将字符串转换为LocalDate对象
LocalDate birthDate = LocalDate.parse(birthDateString);
// 计算用户的年龄
int age = Period.between(birthDate, currentDate).getYears();
// 打印用户的年龄
System.out.println("用户的年龄是:" + age);
user.setAge(age);
return ajax;
}
上述代码是springboot的Controller层中的,该代码通过用户的id查询到用户信息,并取出用户的生日(年-月-日)格式,并与当前日期进行差值计算,得到用户的年龄。
3.运行结果
从数据表中可以看到id为123457的用户信息,他的生日为2001-10-23。
传入该用户的id并调用上述getInfo()方法,年龄计算正确。结果如下图所示: