1. 科普下润年:

①、非整百年能被4整除的为闰年。(如2004年就是闰年,2100年不是闰年)
②、整百年能被400整除的是闰年。(如2000年是闰年,1900年不是闰年)
 
2. 例:
例如:当前日期是2016年8月21日,有人出生在1972年2月29日,查询后该用户最近的生日应该是2017年3月1日(非闰年)。如果当前日期是2016年1月20日,那么查询后应该返回2016年2月29日(闰年)。
 
3. 初始数据

先安装mysql官方示例数据库employees。没安装的可以参考:《MAC安装MYSQL官方示例数据库EMPLOYEE

  • 脚本操作:
-- 创建表employees
create table employees like employees.employees;
-- 将employees库的employees表数据插入到自己的表
insert into employees
select * from employees.employees limit ,;
-- 新增数据,生日为闰年1972-02-29
insert into employees
select '','1972-02-29','Jiang','David','M','1990-2-20';

4. 查询用户和出生信息

  • 语句:
-- 查询用户和出生信息
select concat(e.last_name, ' ', e.first_name) as Name, e.birth_date as BirthDate from employees e;
  • 查询结果:

5. 实现

  5.1 查询当前日期、当前日期和生日间隔的年数。

    • 代码:
    • select concat(e.last_name, '  ', e.first_name) as Name,
      e.birth_date as BirthDay,
      (year(now())-year(e.birth_date)) diff,
      now() as today
      from employees e
    • 结果:

      

        

  5.2 查询当年的生日和下一年的生日。

    • 代码:

      select name,birthday,today,
      date_add(birthday, interval diff year) curr, -- 当年生日
      date_add(birthday, interval diff+ year) next -- 下一年生日
      from (
      select concat(e.last_name, ' ', e.first_name) as Name,
      e.birth_date as BirthDay,
      (year(now())-year(e.birth_date)) diff,
      now() as today
      from employees e
      ) as a
    • 查询结果

      

   5.3 出生日期是29日,当年或下一年生日是28日,就将生日日期加1天

    • 代码:

      select name,birthday,today,
      date_add(curr, interval if(day(birthday)= && day(curr)=, , ) day) as cur, -- 闰年运行后的当年生日
      date_add(next, interval if(day(birthday)= && day(next)=, , ) day) as next -- 闰年运行后的下一年生日
      from (
      select name,birthday,today,
      date_add(birthday, interval diff year) curr, -- 当年生日
      date_add(birthday, interval diff+ year) next -- 下一年生日
      from (
      select concat(e.last_name, ' ', e.first_name) as Name,
      e.birth_date as BirthDay,
      (year(now())-year(e.birth_date)) diff,
      now() as today
      from employees e
      ) as a
      ) as b
    • 查询结果:

      

  5.4 最终代码,如果当年生日已经过了就返回下一年生日。

    • 代码:

      select name,birthday,
      if(cur>today, cur, next) as birth_day -- 如果当年生日大于当前日期,生日为今年,否则为下一年
      from(
      select name,birthday,today,
      date_add(curr, interval if(day(birthday)= && day(curr)=, , ) day) as cur, -- 闰年运行后的当年生日
      date_add(next, interval if(day(birthday)= && day(next)=, , ) day) as next -- 闰年运行后的下一年生日
      from (
      select name,birthday,today,
      date_add(birthday, interval diff year) curr, -- 当年生日
      date_add(birthday, interval diff+ year) next -- 下一年生日
      from (
      select concat(e.last_name, ' ', e.first_name) as Name,
      e.birth_date as BirthDay,
      (year(now())-year(e.birth_date)) diff,
      now() as today
      from employees e
      ) as a
      ) as b
      ) as c
    • 查询结果:

      

  

MySql生日闰月处理的更多相关文章

  1. mysql--SQL编程(关于mysql中的日期,实例,判断生日是否为闰年) 学习笔记2.1

    关于日期处理的实例: 从mysql给出的 example 这个是官方源码下载以及导入,http://dev.mysql.com/doc/employee/en/employees-installati ...

  2. [MySQL]-->询5 几天之内解决在新年发行一个同事的生日过程

    前言:        遇到朋友提问,例如以下:SELECT * FROM ali_users WHERE  DATEDIFF(CAST(CONCAT(DATE_FORMAT(NOW(),'%y'),D ...

  3. [MySQL]-->查询5天之内过生日的同事中的闰年2月29日问题的解决过程

    前言: 上次写了查询5天之内过生日的同事中的跨年问题的解决过程,网址为:http://blog.csdn.net/mchdba/article/details/38952033 ,当中漏了一个闰年2月 ...

  4. mysql 年龄计算(根据生日字段)

    mysql 年龄计算(根据生日字段) year( from_days( datediff( now( ), birthdate))) //获取年龄 now() 当前时间,精确到秒 datediff(b ...

  5. mysql 计算生日

    生日(DATE) 计算方法1: YEAR(CURDATE())-YEAR(birthday)-(RIGHT(CURDATE(),5)<RIGHT(birthday,5)) 计算方法2: year ...

  6. MySql查询生日的两种方式

    需要是要查询日期段内过生日的会员,分为两种情况: 1. 不跨年 例如: 查询2017-01-01到2017-01-20之间过生日的会员  (假定今天是2017-01-01则这种也可以描述为20天内过生 ...

  7. MySQL - 统计每个月生日的人数

    Person表定义如下: create table person(id int primary key auto_increment, birthday datetime); Person 数据如下: ...

  8. mysql 年龄计算(根据生日)

    生日(DATE) 计算方法1: ))) 计算方法2: year( from_days( datediff( now( ), birthdate))) now() 当前时间,精确到秒 datediff( ...

  9. mysql从身份证号中提取生日、性别

    SELECT p.ID, p.IDCardNo, IF ( LENGTH(p.IDCardNo) , CAST( , ) AS DATETIME ), CAST( CONCAT( ', , ) ) A ...

随机推荐

  1. C#- 反射之 GetType()方法

    Type.GetType()在跨程序集反射时返回null的解决方法 在开发中,经常会遇到这种情况,在程序集A.dll中需要反射程序集B.dll中的类型.如果使用稍有不慎,就会产生运行时错误.例如使用T ...

  2. 怎么实时查看mysql当前连接数

    如何实时查看mysql当前连接数? 如何实时查看mysql当前连接数? .查看当前所有连接的详细资料: ./mysqladmin -uadmin -p -h10. processlist .只查看当前 ...

  3. Chrome渲染Transition时页面闪动Bug

    前段时间,有同事和会员反馈使用Chrome访问淘宝首页会出现画面闪动的现象,但是我在Mac和Win下面的Chrome都无法重现这个问题,后来重装了一遍Win7下的Chrome Beta版本,终于重现了 ...

  4. Unity3D基础知识梳理

    这段时间在做Unity的项目,这差不多是我的第一次实战啊~然后公司来了实习的童鞋要学Unity,但是我一向不靠谱啊,所以只能帮他们稍微梳理下基础的东西了啊,唉~学长只能帮你们到这里了~顺便就把自己这两 ...

  5. osip结构体

    /** * Structure for SIP Message (REQUEST and RESPONSE). * @struct osip_message */  struct osip_messa ...

  6. Jquery数组操作

    jQuery的数组处理,便捷,功能齐全. 最近的项目中用到的比较多,深感实用,一步到位的封装了很多原生js数组不能企及的功能. 最近时间紧迫,今天抽了些时间回过头来看 jQuery中文文档 中对数组的 ...

  7. tomcat配置及优化

    jdk安装 su - root mkdir jdk cd jdk wget https://mirror.its.sfu.ca/mirror/CentOS-Third-Party/NSG/common ...

  8. Maven学习8-使用Maven构建多模块项目

    在平时的Javaweb项目开发中为了便于后期的维护,我们一般会进行分层开发,最常见的就是分为domain(域模型层).dao(数据库访问 层).service(业务逻辑层).web(表现层),这样分层 ...

  9. SpringMVC学习系列(2) 之 经典的HelloWorld实现

    前一篇简单介绍了Spring MVC的一些知识,下面就要开始学习如何把Spring MVC运用到具体的项目中去. 首先还是从一个简单的Hello World项目说起: 我机器的开发环境为: Ubunt ...

  10. overload, override和overwrite之间的区别

    Overload.Overwrite和Override的概念比较容易混淆,而且Overwrite和Override的中文翻译五花八门,让人很Confuse,顾保持英文原意: Overload  重载 ...