gpt4 book ai didi

ruby-on-rails - Rails 时间在控制台 session 过程中不会改变

转载 作者:数据小太阳 更新时间:2023-10-29 08:39:13 25 4
gpt4 key购买 nike

我正在开发 Rails 3.2 应用程序。我们在 Ruby 1.9.3 和 Postgres 9.1.3 上运行。网站上的大部分内容都是按 published_at 日期时间戳组织的。面向公众的查询要求提供与 Time.zone.now 相关的内容:

Post.where(["published_at <= ?", Time.zone.now])

加载控制台并询问此帖子时,生成了此查询:

SELECT "posts".* FROM "posts" WHERE (published_at <= '2013-02-25 16:32:19.852109')

然后 10 分钟后在同一个控制台 session 中:

SELECT "posts".* FROM "posts" WHERE (published_at <= '2013-02-25 16:32:19.852109')

请注意,Rails 注入(inject)查询的时间没有改变。如果我运行几个小时的本地开发 session ,Rails 注入(inject)的时间戳总是相同的。

此外,我尝试将 Time.zone.now 换成 Time.now 甚至 Time.new,结果都一样。

最佳答案

像这样重写你的范围:

scope :myscope, ->{ where(["published_at <= ?", Time.zone.now]) }

Time.zone.now 显示为“卡住”,因为作用域宏仅执行一次(加载类时)。使用 lambda 可以防止这种情况。

关于ruby-on-rails - Rails 时间在控制台 session 过程中不会改变,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15071930/

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