注:where语句后中的字段last_login_time 替换成 时间字段名 便可
#查询昨天登陆用户的帐号 select mobile,last_login_time from user where TO_DAYS(NOW())-TO_DAYS(last_login_time)=1; #查询当天登陆用户的帐号 select mobile,last_login_time from user where TO_DAYS(NOW())-TO_DAYS(last_login_time)<1; #查询全部last_login_time值在最后1天内的记录 select mobile,last_login_time from user where TO_DAYS(NOW())-TO_DAYS(last_login_time)<=1; #查询近7天登陆用户的帐号 select mobile,last_login_time from user where DATE_SUB(CURDATE(),INTERVAL 2 DAY)<date(last_login_time); *解释:INTERVAL 1 DAY ,解释为将时间间隔设置为1天
#查询一周内的登陆用户的帐号 select mobile,last_login_time from user where last_login_time between current_date()-7 and sysdate(); #查询本月的登陆用户帐号 select mobile,last_login_time from user where DATE_FORMAT(last_login_time,'%Y%M')= DATE_FORMAT(CURDATE(),'%Y%M'); #查询上一月的登陆用户帐号 select mobile,last_login_time from user where PERIOD_DIFF(date_format(now(),'%Y%m'),date_format(last_login_time,'%Y%m' ) ) =1;
注意:若是数据库中时间已UNIX时间戳的形式存放的话,在时间对比上须要更改成统一格式;
DATE_SUB()返回的是格式化的时间:2019-10-29
须要使用UNIX_TIMESTAMP()转化UNIX时间戳形式对比:
代码以下:
where inputtime>UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 1 DAY))
(1)WEEKDAY(date) 做用:返回 date 的星期索引(0 = Monday, 1 = Tuesday, ... 6 = Sunday) SELECT WEEKDAY(’1997-11-05’); 返回结果:-> 2 (2) DAYOFMONTH(date)
做用:返回 date 是一月中的第几天,范围为 1 到 31:
mysql> SELECT DAYOFMONTH(’1998-02-03’);
返回结果:-> 3
(3)DAYOFYEAR(date)
做用:返回 date 是一年中的第几天,范围为 1 到 366:
mysql> SELECT DAYOFYEAR(’1998-02-03’);
返回结果:-> 34
(4)DAYNAME(date)
做用:返回 date 的星期名:mysql
mysql> SELECT DAYNAME("1998-02-05");
-> ’Thursday’sql
(5)MONTHNAME(date)数据库
做用:返回 date 的月份名:spa
mysql> SELECT MONTHNAME("1998-02-05");
-> ’February’code
(6)QUARTER(date)orm
做用:返回 date 在一年中的季度,范围为 1 到 4:blog
mysql> SELECT QUARTER(’98-04-01’);
-> 2索引