MySql生日闰月处理
1. 科普下润年:
先安装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生日闰月处理的更多相关文章
- mysql--SQL编程(关于mysql中的日期,实例,判断生日是否为闰年) 学习笔记2.1
关于日期处理的实例: 从mysql给出的 example 这个是官方源码下载以及导入,http://dev.mysql.com/doc/employee/en/employees-installati ...
- [MySQL]-->询5
几天之内解决在新年发行一个同事的生日过程
前言: 遇到朋友提问,例如以下:SELECT * FROM ali_users WHERE DATEDIFF(CAST(CONCAT(DATE_FORMAT(NOW(),'%y'),D ...
- [MySQL]-->查询5天之内过生日的同事中的闰年2月29日问题的解决过程
前言: 上次写了查询5天之内过生日的同事中的跨年问题的解决过程,网址为:http://blog.csdn.net/mchdba/article/details/38952033 ,当中漏了一个闰年2月 ...
- mysql 年龄计算(根据生日字段)
mysql 年龄计算(根据生日字段) year( from_days( datediff( now( ), birthdate))) //获取年龄 now() 当前时间,精确到秒 datediff(b ...
- mysql 计算生日
生日(DATE) 计算方法1: YEAR(CURDATE())-YEAR(birthday)-(RIGHT(CURDATE(),5)<RIGHT(birthday,5)) 计算方法2: year ...
- MySql查询生日的两种方式
需要是要查询日期段内过生日的会员,分为两种情况: 1. 不跨年 例如: 查询2017-01-01到2017-01-20之间过生日的会员 (假定今天是2017-01-01则这种也可以描述为20天内过生 ...
- MySQL - 统计每个月生日的人数
Person表定义如下: create table person(id int primary key auto_increment, birthday datetime); Person 数据如下: ...
- mysql 年龄计算(根据生日)
生日(DATE) 计算方法1: ))) 计算方法2: year( from_days( datediff( now( ), birthdate))) now() 当前时间,精确到秒 datediff( ...
- mysql从身份证号中提取生日、性别
SELECT p.ID, p.IDCardNo, IF ( LENGTH(p.IDCardNo) , CAST( , ) AS DATETIME ), CAST( CONCAT( ', , ) ) A ...
随机推荐
- 关于斐波拉契数列(Fibonacci)
斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10 ...
- 程序跳转到访问一个确定的地址0x100000
用函数指针 把这个确定的地址转化成一个函数指针 这就明白了程序中调用函数的意义 测试代码如下: #include <stdio.h> void getMemory() { printf(& ...
- SCRUM项目 6.0
6.0----------------------------------------------------- sprint演示 1.坚持所有的sprint都结束于演示. 团队的成果得到认可,会感觉 ...
- javac
http://openjdk.java.net/groups/compiler/ http://crazyjavahacking.org/tag/javac/ http://openjdk.java. ...
- Pycharm 使用配置
配置一下Pycharm吧,不然用着头疼 常用设置: 1. pycharm默认是自动保存的,习惯自己按ctrl + s 的可以进行如下设置: 1). file -> Setting -> G ...
- Python UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-4: ordinal not in range(128)
#!/usr/bin/python# -*- coding: utf-8 -*- 解决方法: 可以看到我的版本是2.6的,所以打开/usr/lib64/python2.6/site.py 红框里本来是 ...
- ObjectID和Handle
一个dwg对应一个arx database,也就是一套9个符号表和一个有名词典. 一个CAD session中是可以加载多个database的.加载后每个对象都有一个handle和一个objectid ...
- [转]C#创建Windows服务与安装
本文档用于创建windows服务说明,使用vs2010系统平台 创建项目 1 创建windows服务项目 2 右键点击Service1.cs,查看代码, 用于编写操作逻辑代码 3 代码中OnStart ...
- perl读取文件
1)文件读取的3中方法 按行读,存入标量 while (<FILE>) { print; } 按行读,存入数组 @array = <FILE>; 读入整个文件 ,存入标量 ...
- Hadoop学习15--编程相关
1.新版本:mapreduce包 2.job设置: a.JobName便于调试 b.FileInputFormat.addInputPath 添加输入路径,可添加多个:可以是具体文件,还可以是文件夹. ...