在我的 SQLite- DB 中,我想在星期一选择所有条目 。
我怎么能用塞克尔呢?
试验示例:
require sequel
DB = Sequel.sqlite()# test.db )
DB.create_table(:days) do
String :text
Date :start
end
Date.today.upto(Date.today + 30){|d|
DB[:days].insert( :text => d.strftime("%Y-%m-%d day %w in week %W"), :start => d)
}
我怎么能选择每个星期一?
select * from days where strftime("%w", start) = "1"
使用此选项, 我可以定义一个视图, 并为此选择 :
DB.run( create view mondays as select * from days where strftime("%w", start) = "1" )
p DB[:mondays].all
但我想用塞克尔的
我试过了
sel = DB[:days].filter{ start.strftime("%w", :start) == 1 }
#NoMethodError
sel = DB[:days].filter{ Sequel::SQL::Function.new(:strftime, "%w", :start) == 1 }
#SELECT * FROM `days` WHERE (1 = 0)
但没有成功。
还有其他解决办法吗?
我还在寻找按时选择项目的可能性(所有项目都有一个时间戳,然后从中午12:00至13:00),我认为这是同样的问题,周选一日的解决方案也将解决我的另一个问题。