SQL | 时间函数

1 函数1:MySQL DATEDIFF() 函数

在这里插入图片描述
总结:

  • MySQL DATEDIFF() 函数中只有两个参数,即两个时间,返回结果是前面的时间减去后面的时间
  • 注意时间的格式要求:‘2008-12-30’ 如果不是这种格式,得首先进行格式的修改,修改的SQL语句见下面:
datediff(concat(substr(t1.day,1,4),'-',substr(t1.day,5,2),'-',substr(t1.day,7,2)),concat(substr(t2.day,1,4),'-',substr(t2.day,5,2),'-',substr(t2.day,7,2))) as diff
  • 即使用concat函数进行字符串的连接,中间记得加上 ‘-’ 然后concat函数中的参数是逗号相连接!
  • 另外SQL中的substr函数类似于python:
substr(str, start, length)

注意第二个参数是截取字符串的长度!来看个具体的例子就很清晰了!
在这里插入图片描述

2 函数2: SQL Server DATEDIFF() 函数

这个函数和上面的会有些差别,具体的差异体现在下面两个地方:

  • 第一个差异是:函数内参数有3个!
DATEDIFF(datepart,startdate,enddate)

其中datepart可以为下面这些参数:
在这里插入图片描述
另外两个参数和上述的时间函数保持一致

  • 第二个差异就是在计算方式存在差异,第一个时间函数是前面的时间减去后面的时间,而这个函数则是 :后面的时间减去前面的时间!举个栗子!
    在这里插入图片描述

3 总结

  • datediff函数有两种:MySQL和SQL Server中
  • 差异:参数个数和计算方式不同
  • MySQL:2个参数,前-后
  • SQL Server:3个参数,后-前

4 参考资料

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值