热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

mysql计算离生日还有多少天(过了今年就按下年计算)

mysql计算离生日还有多少天(过了今年就按下年计算)表1:www.2cto.comnamebirthday离生日天数aaaa2012-12-075bbbb2013-01-0534sql:Java代码SELECT...SyntaxHighlighter.all();

mysql计算离生日还有多少天(过了今年就按下年计算)
 
表1: www.2cto.com  
     name   birthday        离生日天数 
     aaaa       2012-12-07     5 
     bbbb       2013-01-05      34 
sql: 
Java代码  
SELECT a.* FROM   
(SELECT t.name,t.birthday,CASE WHEN t.b>0 THEN t.b ELSE t.a END days FROM (  
SELECT NAME,birthday ,DATEDIFF(CONCAT(DATE_FORMAT(NOW(),'%Y')+1,DATE_FORMAT(birthday,'-%m-%d')),NOW()) a,  
DATEDIFF(CONCAT(DATE_FORMAT(NOW(),'%Y'),DATE_FORMAT(birthday,'-%m-%d')),NOW()) b  
FROM  hy_member) t) a WHERE a.days BETWEEN 0 AND 40;  
 
mysql 日期一些函数 
 
1. MySQL 为日期增加一个时间间隔:date_add() 
 
set @dt = now(); 
 
select date_add(@dt, interval 1 day);   - 加1天 
 
select date_add(@dt, interval 1 hour);   -加1小时 
 
select date_add(@dt, interval 1 minute);    - 加1分钟 
 
select date_add(@dt, interval 1 second); -加1秒 
 
select date_add(@dt, interval 1 microsecond);-加1毫秒 
 
select date_add(@dt, interval 1 week);-加1周 
 
select date_add(@dt, interval 1 month);-加1月 
 
select date_add(@dt, interval 1 quarter);-加1季 
 
select date_add(@dt, interval 1 year);-加1年 
 
MySQL adddate(), addtime()函数,可以用date_add() 来替代。下面是date_add() 实现addtime() 功能示例: 
 
mysql> set @dt = '2009-09-09 12:12:33'; 
 
mysql> 
 
mysql> select date_add(@dt, interval '01:15:30' hour_second);-加上1小时15分30秒 
 
date_add(@dt, interval '01:15:30' hour_second) 
 
结果:2009-09-09 13:28:03 
 
mysql> select date_add(@dt, interval '1 01:15:30' day_second);-加1天1小时15分30秒 
 
date_add(@dt, interval '1 01:15:30' day_second) 
 
2008-08-10 13:28:03 
 
date_add() 函数,分别为@dt 增加了“1小时15分30秒” 和 “1天1小时15分30秒” 
 
2. MySQL 为日期减去一个时间间隔:date_sub() 
 
mysql> select date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second); 
 
date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second) 
 
www.2cto.com 
 
MySQL date_sub() 日期时间函数 和date_add() 用法一致,不再赘述。另外,MySQL 中还有两个函数subdate(), subtime(),建议,用date_sub() 来替代。 
 
3. MySQL 另类日期函数:period_add(P,N), period_diff(P1,P2) 
 
函数参数“P” 的格式为“YYYYMM” 或者 “YYMM”,第二个参数“N” 表示增加或减去N month(月)。 
 
MySQL period_add(P,N):日期加/减去N月。 
 
mysql> select period_add(200808,2), period_add(20080808,-2) 
 
| period_add(200808,2) | period_add(20080808,-2) | 
 
结果|               200810 |                20080806 | 
 
MySQL period_diff(P1,P2):日期P1-P2,返回N 个月。 
 
mysql> select period_diff(200808, 200801); 
 
period_diff(200808, 200801) 
 
  结果:7 
 
MySQL 中,这两个日期函数,一般情况下很少用到。 
 
4. MySQL 日期、时间相减函数:datediff(date1,date2), timediff(time1,time2) 
 
MySQL datediff(date1,date2):两个日期相减date1 date2,返回天数。网站制作学习网整理 
 
select datediff('2008-08-08', '2008-08-01'); - 7 
 
select datediff('2008-08-01', '2008-08-08'); -7 
 
MySQL timediff(time1,time2):两个日期相减time1 time2,返回time 差值。 
 
select timediff('2008-08-08 08:08:08', '2008-08-08 00:00:00');- 08:08:08 
 
select timediff('08:08:08', '00:00:00');                      - 08:08:08 
 
注意:timediff(time1,time2) 函数的两个参数类型必须相同。
 

推荐阅读
  • 本文由公众号【数智物语】(ID: decision_engine)发布,关注获取更多干货。文章探讨了从数据收集到清洗、建模及可视化的全过程,介绍了41款实用工具,旨在帮助数据科学家和分析师提升工作效率。 ... [详细]
  • 本文深入探讨了MySQL中的高级特性,包括索引机制、锁的使用及管理、以及如何利用慢查询日志优化性能。适合有一定MySQL基础的读者进一步提升技能。 ... [详细]
  • 在使用mybatis进行mapper.xml测试的时候发生必须为元素类型“mapper”声明属性“namespace”的错误项目目录结构UserMapper和UserMappe ... [详细]
  • Windows环境下Oracle数据库迁移实践
    本文详细记录了一次在Windows操作系统下将Oracle数据库的控制文件、数据文件及在线日志文件迁移至外部存储的过程,旨在为后续的集群环境部署做好准备。 ... [详细]
  • Java连接MySQL数据库的方法及测试示例
    本文详细介绍了如何安装MySQL数据库,并通过Java编程语言实现与MySQL数据库的连接,包括环境搭建、数据库创建以及简单的查询操作。 ... [详细]
  • 本文详细介绍了如何使用SQL*Plus连接Oracle数据库以及使用MySQL客户端连接MySQL数据库的方法,包括基本命令和具体操作步骤。 ... [详细]
  • 本文探讨了如何使用Scrapy框架构建高效的数据采集系统,以及如何通过异步处理技术提升数据存储的效率。同时,文章还介绍了针对不同网站采用的不同采集策略。 ... [详细]
  • PHP中Smarty模板引擎自定义函数详解
    本文详细介绍了如何在PHP的Smarty模板引擎中自定义函数,并通过具体示例演示了这些函数的使用方法和应用场景。适合PHP后端开发者学习。 ... [详细]
  • 本文通过一系列实验,探讨了Oracle 11g数据库中密码错误验证延迟特性对用户登录速度的影响。实验旨在验证当某个用户因输入错误密码而触发延迟时,是否会影响其他用户的正常登录速度。 ... [详细]
  • SQL查询与事务管理:深入解析
    本文详细介绍了SQL查询的基本结构和高级特性,包括选择、分组查询以及权限控制等内容,并探讨了事务管理中的并发控制策略,旨在为数据库管理员和开发人员提供实用指导。 ... [详细]
  • PHP 图形函数中实现汉字显示的方法
    本文详细介绍了如何在 PHP 的图形函数中正确显示汉字,包括具体的步骤和注意事项,适合初学者和有一定基础的开发者阅读。 ... [详细]
  • 2023年1月28日网络安全热点
    涵盖最新的网络安全动态,包括OpenSSH和WordPress的安全更新、VirtualBox提权漏洞、以及谷歌推出的新证书验证机制等内容。 ... [详细]
  • 将XML数据迁移至Oracle Autonomous Data Warehouse (ADW)
    随着Oracle ADW的推出,数据迁移至ADW成为业界关注的焦点。特别是XML和JSON这类结构化数据的迁移需求日益增长。本文将通过一个实际案例,探讨如何高效地将XML数据迁移至ADW。 ... [详细]
  • 面对众多的数据分析工具,如何选择最适合自己的那一个?对于初学者而言,了解并掌握几种核心工具是快速入门的关键。本文将从数据处理的不同阶段出发,推荐三种广泛使用的数据分析工具。 ... [详细]
  • 本文探讨了如何在SQL Server Reporting Services (SSRS)中利用TOP N功能来筛选和展示数据集中的前N条记录。通过正确的配置图表属性中的筛选器设置,可以轻松实现这一目标。 ... [详细]
author-avatar
天佑忍者忍着
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有