您需要使用to_char() 来获取日期编号,但您可以将其转换为数字:
select dateSold, sum(quantity) from sales
where to_number(to_char(dateSold, 'D')) in (1, 3, 4, 7)
但是D 是依赖于 NLS 的,因此如果您在美国与法国的会话中运行它,您会得到不同的结果。这可能就是您看到字符串比较的原因,因为您至少可以控制更多:
select dateSold, sum(quantity) from sales
where to_char(dateSold, 'DY', 'NLS_DATE_LANGUAGE=ENGLISH') in ('MON', 'WED', 'THU', 'SUN')
要查看 NLS 设置的不同之处,这会显示相同数据和查询的 D 和 DY 值,就像在美国运行一样:
alter session set nls_territory = 'AMERICA';
alter session set nls_language = 'ENGLISH';
with cte (dateSold) as (
select date '2018-08-01' + level - 1 from dual connect by level <= 7
)
select dateSold,
to_number(to_char(dateSold, 'D')) as d,
to_char(dateSold, 'DY') as dy,
to_char(dateSold, 'DY', 'NLS_DATE_LANGUAGE=ENGLISH') as dy_english
from cte;
DATESOLD D DY DY_ENGLISH
--------- ---------- ------------ ------------
01-AUG-18 4 WED WED
02-AUG-18 5 THU THU
03-AUG-18 6 FRI FRI
04-AUG-18 7 SAT SAT
05-AUG-18 1 SUN SUN
06-AUG-18 2 MON MON
07-AUG-18 3 TUE TUE
然后就像在法国跑步:
alter session set nls_territory = 'FRANCE';
alter session set nls_language = 'FRENCH';
with cte (dateSold) as (
select date '2018-08-01' + level - 1 from dual connect by level <= 7
)
select dateSold,
to_number(to_char(dateSold, 'D')) as d,
to_char(dateSold, 'DY') as dy,
to_char(dateSold, 'DY', 'NLS_DATE_LANGUAGE=ENGLISH') as dy_english
from cte;
and the same thing as if run in the USA:
DATESOLD D DY DY_ENGLISH
-------- ---------- ---------------- ------------
01/08/18 3 MER. WED
02/08/18 4 JEU. THU
03/08/18 5 VEN. FRI
04/08/18 6 SAM. SAT
05/08/18 7 DIM. SUN
06/08/18 1 LUN. MON
07/08/18 2 MAR. TUE
请注意,日期编号和名称/缩写完全不同,因此尝试将它们与固定值进行比较 - 无论是 in (1, 3, 4, 7) 还是使用字符串文字日期名称 - 都不会可靠地匹配。
将日期语言强制为英语使比较安全。 (当然,或者任何其他语言 - 字符串文字值只需与您为 to_char() 的第三个参数选择的语言匹配。)