检查当前日期是否在天数限制字段日期MYSQL内

时间:2014-07-22 12:19:33

标签: php mysql intervals unix-timestamp

在我的项目中,我需要用户订阅的计划未过期。当用户订阅计划时,它将输入表 usersubscription ,其结构如下所示:

id  user_id   plan_id  subscribed_on

用于存储计划详细信息的表是 subscription_plans

id  plan   days_limit  discounted_rate  added_on    status  rate
1   PlanJ  30          240              1403094260  1       245.00

此表格将包含项目中订阅计划的详细信息。视频可以是一个或多个计划的一部分。如果某个视频符合规划,则会将其存储在数据库 subscribed_videos 中。

id   plan_id  videoid

此外,计划也可以成为另一个计划的一部分。这是假设有计划说A和B.视频1是计划B的一部分,并计划包含计划B(相关计划)。因此,如果用户订阅了计划A,则计划B中的视频将可用于他。关联计划的表格是 subscription_groups 。结构在下面分享:

id  plan_id  assosiated_plan_id  added_on

我需要检查用户是否订阅了未过期的计划(包含所选视频)(即,它将在 subscribed_on + days_limit 天过期)。我现在使用的当前查询是

    select u.id,sp.days_limit from usersubscription as u INNER JOIN subscription_plans as 
sp ON sp.id=u.plan_id where (plan_id IN ( ( SELECT DISTINCT plan_id FROM subscribed_videos
 sv where sv.videoid = 57 ) ) OR id IN ( SELECT DISTINCT assosiated_plan_id AS plan_id FROM
subscription_groups sg JOIN subscribed_videos sv ON sv.plan_id = sg.plan_id WHERE 
sv.videoid = 57 ) ) and u.user_id=1 AND DATE_ADD(FROM_UNIXTIME(u.subscribed_on), INTERVAL 
sp.days_limit DAY) > NOW()

这将检查id为1的用户是否订阅了包含id为57的视频的任何计划(主计划或相关计划)。我将日期保存为整数(unix timestamp)。

任何人都可以帮我找到解决方案吗?请查看此SQL FIDDLE

提前致谢

1 个答案:

答案 0 :(得分:1)

错误已解决。 Check here

只需将子查询中的OR子句后面的id指向您想要的字段