文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

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语句日期相减内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯