sql语句中日期相减的操作实例代码

 更新时间:2022年09月18日 12:08:26   作者:孙永潮  
在工作中遇到时间处理,学习了一下SQL的日期处理方面,下面这篇文章主要给大家介绍了关于sql语句中日期相减操作的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

1. 直接用日期时间做减法

GETDATE() 和 NOW() 查出来的时间一样,都带时分秒

select GETDATE(),NOW() FROM t_表名;

curdate() 只显示 年月日

select curdate(),NOW() FROM TB_表名;

如果直接做减法,只能得到两个时间相差多少天

select (NOW()-日期时间字段) FROM T_表名;

若不要 时分秒,可以考虑用 curdate()

select (curdate()-日期时间字段) FROM T_表名;

2. 使用 datediff 函数

datediff 函数还有其他的玩法,在这就不多加赘述了。 两日期 间隔年

select datediff(year, 开始日期,结束日期) FROM T_表名;;

俩日期 间隔季

select datediff(quarter, 开始日期,结束日期) FROM T_表名;

俩日期 间隔月

select datediff(month, 开始日期,结束日期) from 表名;

俩日期 间隔天

select datediff(day, 开始日期,结束日期) FROM T_表名; 

俩日期 间隔周

select datediff(week, 开始日期,结束日期) FROM T_表名;

俩日期 间隔小时

select datediff(hour, 开始日期,结束日期) FROM T_表名;

俩日期 间隔分

select datediff(minute, 开始日期,结束日期) FROM T_表名;

俩日期 间隔秒

select datediff(second, 开始日期,结束日期) FROM T_表名; 

获取近 7 天 的年月日,包括今天

select (CURDATE() - 6) as dateList
union
select (CURDATE() - 5) as dateList
union
select (CURDATE() - 4) as dateList
union
select (CURDATE() - 3) as dateList
union
select (CURDATE() - 2) as dateList
union
select (CURDATE() - 1) as dateList
union
select (CURDATE() - 0) as dateList

查询 当前 年月日 时分秒

SELECT NOW(), CURDATE(), CURTIME()

好的代码像粥一样,都是用时间熬出来的

补充:下面来看个实例

我有一个表,其中有四个字段:开始天数,开始时间,到达天数,到达时间(这四个字段都是varchar类型)

例如:某一条记录: 1 16:00 2 12:20

我的目的就是用 select(到达天数+到达时间)-(开始天数+开始时间) as 花费时间 from table

例如上条记录得到的就是 (2*24:00+12:20)-(24:00+16:00)=20:00

这样的sql语句该怎么写???

declare @t table
(
beginday int,
begintime varchar(20),
endday int,
endtime varchar(20)
)

insert @t select 1,"16:00",2,"12:20"
union all select 1,"3:00",3,"19:10"
select

date=rtrim(date/60)+":"+rtrim(date%60)
from
(select date=datediff(mi,1,dateadd(d,endday-beginday,beginday)-begintime+endtime)from @t )t
date
-------------------------
20:20
64:10

方法二

declare @t table(开始天数 varchar(10),开始时间 varchar(10),到达天数 varchar(10),到达时间 varchar(10))
insert @t select "1", "16:00","2","12:20"
--如果开始天数,到达天数大于31
select 到达天数 * 24 + datepart(hh,到达时间) - 开始天数 * 24 - datepart(hh,开始时间)
from @t

总结

到此这篇关于sql语句中日期相减操作的文章就介绍到这了,更多相关sql语句日期相减内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql索引结合explain分析示例

    Mysql索引结合explain分析示例

    本文主要介绍了Mysql索引结合explain分析示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • MySQL为JSON字段创建索引方式(Multi-Valued Indexes 多值索引)

    MySQL为JSON字段创建索引方式(Multi-Valued Indexes 多值索引)

    这篇文章主要介绍了MySQL为JSON字段创建索引方式(Multi-Valued Indexes 多值索引),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • Mysql:The user specified as a definer (''xxx@''%'') does not exist的解决方案

    Mysql:The user specified as a definer (''xxx@''%'') does not

    今天小编就为大家分享一篇关于Mysql:The user specified as a definer ('xxx@'%') does not exist的解决方案,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • 一文搞懂Mysql数据库中的各种日志

    一文搞懂Mysql数据库中的各种日志

    MySQL日志的内容非常重要,面试中经常会被问到,下面这篇文章主要给大家介绍了关于Mysql数据库中各种日志的相关资料,文中通过代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-08-08
  • MYsql库与表的管理及视图介绍

    MYsql库与表的管理及视图介绍

    这篇文章主要介绍了MYsql库与表的管理及视图介绍,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • mysql免安装版配置步骤详解分享

    mysql免安装版配置步骤详解分享

    这篇文章主要介绍了mysql免安装版配置步骤详解,提供了二个网友的安装方法,大家可以参考使用
    2013-12-12
  • MySQL4 File ‘c:\mysql\share\charsets\?.conf’ not found (Errcode: 22)的解决方法

    MySQL4 File ‘c:\mysql\share\charsets\?.conf’ not found (Errc

    File ‘c:\mysql\share\charsets\?.conf’ not found (Errcode: 22) Character set ‘#33′ is not a compiled character set and is not specified in the ‘c:\mysql\share\charsets\Index’ file
    2013-08-08
  • oracle/mysql数据库多条重复数据如何取最新的

    oracle/mysql数据库多条重复数据如何取最新的

    最近开发的时候遇到一个任务,需要对重复的数据进行筛选,只取插入时间最早的一条数据,这篇文章主要给大家介绍了关于oracle/mysql数据库多条重复数据如何取最新的相关资料,需要的朋友可以参考下
    2024-08-08
  • MySql中的IFNULL、NULLIF和ISNULL用法详解

    MySql中的IFNULL、NULLIF和ISNULL用法详解

    在做项目中发现MySql里的isnull和mssql里的有点不同。接下来小编通过本文给大家介绍MySql中的IFNULL、NULLIF和ISNULL用法详解的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • MySql中 is Null段判断无效和IFNULL()失效的解决方案

    MySql中 is Null段判断无效和IFNULL()失效的解决方案

    这篇文章主要介绍了MySql中 is Null段判断无效和IFNULL()失效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06

最新评论