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个参数,后-前