通常会计算用户登录系统的天数(例如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的技巧
我希望通过一个简单的查询(如果可能)来做到这一点。
答案 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'