gpt4 book ai didi

mysql - 重复日历事件和一些最终数学

转载 作者:IT老高 更新时间:2023-10-29 00:12:17 26 4
gpt4 key购买 nike

我正在尝试使用 PHP/MySQL 处理日历上臭名昭著的重复事件。我终于找到了一些似乎有用的东西。我找到了我的 answer here但我有点难以完成它。

我的第一个表“事件”。

ID    NAME
1 Sample Event
2 Another Event

我的第二个表 'events_meta 存储重复数据。

ID    event_id      meta_key           meta_value
1 1 repeat_start 1336312800 /* May 7th 2012 */
2 1 repeat_interval_1 432000 /* 5 days */

repeat_start 是一个没有时间的日期作为 unix 时间戳,repeat_interval 是间隔之间的秒数(432000 是 5 天)。

然后我从上面的链接中稍微修改了以下 MySQL。下面使用的时间戳(1299132000,即 2012 年 5 月 12 日)是没有时间的当天。

SELECT EV.*
FROM `events` EV
RIGHT JOIN `events_meta` EM1 ON EM1.`event_id` = EV.`id`
RIGHT JOIN `events_meta` EM2 ON EM2.`meta_key` = CONCAT( 'repeat_interval_', EM1.`id` )
WHERE EM1.meta_key = 'repeat_start'
AND (
( CASE ( 1336744800 - EM1.`meta_value` )
WHEN 0
THEN 1
ELSE ( 1336744800 - EM1.`meta_value` ) / EM2.`meta_value`
END
)
) = 1

在上述MySQL中,以下代码从当前日期减去repeat_start字段(EM1.'meta_value'),然后除以重复间隔字段(EM2.'meta_value ').

ELSE ( 1336744800 - EM1.`meta_value` ) / EM2.`meta_value`

TODAYS DATE - START DATE / 5 DAYS

所以这是数学:

1336744800 - 1336312800 = 432000
432000 / 432000 = 1

现在完美了。但是,如果我提前 5 天将当前时间戳更改为 1336312800,即 2012 年第 17 天,它看起来有点像这样:

1336312800 - 1336312800 = 864000
86400 / 432000 = 2

它不起作用,因为它等于 2,而在 MySQL 中它需要等于 1。所以我想我的问题是,如何让 MySQL 识别整数而不是必须这样做?

...
WHERE EM1.meta_key = 'repeat_start'
AND (
( CASE ( 1336744800 - EM1.`meta_value` )
WHEN 0
THEN 1
ELSE ( 1336744800 - EM1.`meta_value` ) / EM2.`meta_value`
END
)
) = IN (1,2,3,4,5,6,7,8,....)

希望我说得有道理,我希望这只是一个简单的数学问题或 MySQL 具有的一个函数可以提供帮助:) 感谢您的帮助!

编辑:答案

感谢下面的@eggypal,我找到了答案,当然很简单!

SELECT EV.*
FROM elvanto_calendars_events AS EV
RIGHT JOIN elvanto_calendars_events_meta AS EM1 ON EM1.`event_id` = EV.`id`
RIGHT JOIN elvanto_calendars_events_meta AS EM2 ON EM2.`meta_key` = CONCAT( 'repeat_interval_', EM1.`id` )
WHERE EM1.meta_key = 'repeat_start'
AND ( ( 1336744800 - EM1.`meta_value` ) % EM2.`meta_value`) = 0

最佳答案

还不完全清楚您希望查询做什么,但是您问题的要点让我倾向于建议您研究模块化算法:在 SQL 中,a % ba 时返回余数除以 b - 如果没有余数(即 a % b = 0 ),则 a必须是 b精确倍数 .

在您的情况下,我认为您正在尝试查找事件开始和某个给定文字之间的时间恰好是事件间隔的倍数的事件:即(literal - event_start) % event_interval = 0 .如果它非零,则该值为 literal 之后下一次出现的时间。 (因此,为了确定下一次事件是否发生在某个时间段内,比如一天,可以测试余数是否小于该常量,例如 (literal - event_start) % event_interval < 86400)。

如果这不是您想要的,请准确说明您的查询要达到的目的。

关于mysql - 重复日历事件和一些最终数学,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10545869/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com