Mysql查询计算登录天数

时间:2012-02-20 11:26:49

标签: mysql sql

通常会计算用户登录系统的天数(例如stackexchange)。在普通用户表中,我将登录信息更新为

UPDATE users SET 
last_login='date', number_of_login=number_of_login + 1, number_of_days=? 
WHERE user_id='user_id'

其中last_date为datetime

最好检查当天是否与last_login不同,以number_of_day=number_of_day+1更新天数。

我有两种方法,但它们似乎很天真:

方法1:使用SELECT来捕获last_login并将其与PHP中的当前日期进行比较

方法2:使用类似子SELECT的技巧

我希望通过一个简单的查询(如果可能)来做到这一点。

2 个答案:

答案 0 :(得分:2)

我会使用DATEDIFF MySql函数:http://dev.mysql.com/doc/refman/5.1/en/date-and-time-functions.html#function_datediff

  

DATEDIFF()返回expr1 - expr2表示为天数值   约会到另一个。 expr1和expr2是日期或日期和时间   表达式。只有值的日期部分用于   计算

获取结果后,应检查fetched列是否大于零,以确定日期是否不同。

答案 1 :(得分:1)

所以,如果我没有弄错你的评论,你想要始终更新last_login,但只有last_login!= curdate()才能更新number_of_days。试试这个:

UPDATE users SET 
number_of_days = if (last_login = curdate(), number_of_days, number_of_days + 1),
last_login='date', number_of_login = number_of_login + 1
WHERE user_id='user_id'