mysql日期相减操作

一、MySQL中两个DateTime字段相减

假定表名为tblName,两个DateTime字段名分别为beginDateTime,endDateTime,以下是相关两个mysql日期字段相减的SQL语句,这种方式两字段跨天,月,年都无问题。

得到两个日期字段之间的秒数

selec t (UNIX_TIMESTAMP(endDateTime) - UNIX_TIMESTAMP(beginDateTime)) dif_second from tblName

得到两个日期字段之间的分数

selec t (UNIX_TIMESTAMP(endDateTime) - UNIX_TIMESTAMP(beginDateTime))/60 dif_minute from tblName

得到两个日期字段之间的天数

selec t (UNIX_TIMESTAMP(endDateTime) - UNIX_TIMESTAMP(beginDateTime))/(60*60*24) dif_minute from tblName

二、MySQL中两个Time字段相减

如果两个字段都为Time类型,如果两个时间都在同一天,相减可以得到相差的秒数,但如果跨天,月,年都有问题。

selec t (TIME_TO_SEC(endDateTime) - TIME_TO_SEC(beginDateTime)) dif_second from tblName

三、MySQL中两个DateTime字段比较

select sum(studychj) as tofflinejz from afterline wherecheckflag=1 and studytype=1 andstudybegin>='2010-01-01 00:00:00' andstudyend<='2010-12-01 00:00:00' andusername='01009'


这么写不报错,但得出结果不准确

 

 

 

方法一:

 

你也可以:
select * from t1 where unix_timestamp(time1) >unix_timestamp('2011-03-03 17:39:05') and unix_timestamp(time1)< unix_
timestamp('2011-03-03 17:39:52');
就是用unix_timestamp函数,将字符型的时间,转成unix时间戳。个人觉得这样比较更踏实点儿。

 

方法二:

 

time1 between '2011-03-03 17:39:05' and '2011-03-0317:39:52';

 

方法三:

可以讲datetime类型转换成date类型再进行比较
例如:convert(date,表名.datetime列名) >=convert(date,表名.datetime列名)


展开阅读全文

没有更多推荐了,返回首页