bru*_*rux 8 sql database sqlite
我有一张桌子,其中包括日期栏servdate.
我使用以下查询来获取过去一周内的所有工作(一周从星期一开始):
SELECT * FROM tb1 WHERE servdate BETWEEN date('now', 'Weekday 1', '-21 days') AND date('now')
Run Code Online (Sandbox Code Playgroud)
我希望查询工作完全相同,而是将servdate字段作为一周中相应的日期返回.例如,"星期一",而不是"2010-11-28".
这可能吗?
Dou*_*rie 22
您可以使用wallyk建议的辅助表; 或者您可以使用case表达式:
select _id, busnum,
case cast (strftime('%w', servdate) as integer)
when 0 then 'Sunday'
when 1 then 'Monday'
when 2 then 'Tuesday'
when 3 then 'Wednesday'
when 4 then 'Thursday'
when 5 then 'Friday'
else 'Saturday' end as servdayofweek
from tb1
where ...
Run Code Online (Sandbox Code Playgroud)
这里的建议涉及比CASE ... WHEN块少打字。在这里,同样通过子串提取来完成:
select substr('SunMonTueWedThuFriSat', 1 + 3*strftime('%w', timestr), 3) as dow
from ...
Run Code Online (Sandbox Code Playgroud)
不过,它只生成固定长度的缩写而不是完整的工作日名称。(但有时这已经足够了。)