关于日期函数next_day()的使用


SQL> select next_day ( to_date ('2006-10-10','yyyy-mm-dd'),'TUESDAY') NEXT_DAY FROM DUAL;
select next_day ( to_date ('2006-10-10','yyyy-mm-dd'),'TUESDAY') NEXT_DAY FROM DUAL
*
ERROR at line 1:
ORA-01846: not a valid day of the week

我明明是按照书本上的语句来执行的,为什么会出错呢?!

原因在于当前的语言环境是中文,它认不得英文!

这样写,就可以了:
-- 既然是中文日期,那我也用中文的写法来表示
SQL> select next_day ( to_date ('2006-10-10','yyyy-mm-dd'),'星期二') NEXT_DAY FROM DUAL;

NEXT_DAY
----------
2006-10-17

或者改变当前会话的日期语言:
SQL> alter session set nls_date_language='american';

Session altered.

SQL> select next_day ( to_date ('2006-10-10','yyyy-mm-dd'),'TUESDAY') NEXT_DAY FROM DUAL;

NEXT_DAY
----------
2006-10-17

-- 除了设置NLS_DATE_LANGUAGE参数之外,还有另外一种办法
-- 这种方法在任何日期语言环境下都适用!
-- 1表示星期日,2表示星期一,依此类推,最大为7

SQL> select next_day(sysdate,2) from dual;

NEXT_DAY(S
----------
2007-04-23

SQL> alter session set nls_date_language='simplified chinese';

Session altered.

SQL> select next_day(sysdate,2) from dual;

NEXT_DAY(S
----------
2007-04-23

[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/17826/viewspace-912016/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/17826/viewspace-912016/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值