Mysql 查詢當天、昨天、近7天、一週內、本月、上一月等的數據(函數執行日期的算術運算)

注: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))

 

(1WEEKDAY(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索引

相關文章
相關標籤/搜索