格式化日期为星期几

时间:2010-11-30 22:22:01

标签: sql database sqlite

我有一张表格,其中包含日期栏servdate

我使用以下查询来获取过去一周内的所有工作(一周从星期一开始):

SELECT * FROM tb1 WHERE servdate BETWEEN date('now', 'Weekday 1', '-21 days') AND date('now')

我希望查询工作完全相同,而是将servdate字段作为一周中相应的日期返回。例如,“星期一”,而不是“2010-11-28”。

这可能吗?

3 个答案:

答案 0 :(得分:21)

你可以使用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 ...

答案 1 :(得分:2)

这是一个涉及比CASE ... WHEN块更少输入的建议。这里,子串提取也是如此:

select substr('SunMonTueWedThuFriSat', 1 + 3*strftime('%w', timestr), 3) as dow
from ...

它只生成固定长度的缩写而不是完整的工作日名称。 (但有时候这已经足够了。)

答案 2 :(得分:-1)

SELECT _id, busnum, date_format(servdate, '%a') as servdayofweek
FROM tb1
WHERE servdate BETWEEN date('now', 'Weekday 1', '-21 days') AND date('now')

%a是一周的缩写日期。有关格式化的其他方法,请参阅documentation


编辑:

糟糕!忽略了sqlite标签。以上是针对MySQL的。对于sqlite(documentation):

SELECT _id, busnum, strftime('%w', servdate) as servdayofweek
FROM tb1
WHERE servdate BETWEEN date('now', 'Weekday 1', '-21 days') AND date('now')

除了这会将星期几作为0到6的值返回。也许这还不错?