格式日期为星期几

问题描述:

我有一个表格,其中包含日期列servdate格式日期为星期几

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

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

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

这可能吗?

+1

wallyk的想法很好,但为了简单起见,我更喜欢“太阳”“mon”而不是“0”“1” – brux 2010-12-01 00:43:43

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

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') 

除了这种通过6.返回星期几作为一个值0也许这是够好?

+1

你好,我跑了查询并得到:SQL错误:没有这样的函数:date_format – brux 2010-11-30 22:43:15

+0

这个代码可以写成返回“mon”而不是“1”等吗? :D – brux 2010-12-01 00:42:56

这里涉及比CASE ... WHEN块打字少了建议。这里,同样是通过提取子串完成:

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

它只能产生固定长度的缩写,而不是完整的星期几的名字,虽然。 (但有时这就够了)