一、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列名)