select to_char(sysdate, 'MM' ) from dual 来获取月份
complete!usetime:16endtimeWedMar1310:14:35CST2013nullCausedexceptionmessageis:transla...
complete! use time:16end time Wed Mar 13 10:14:35 CST 2013null
Caused exception message is: translate sql exception, message is
format sql error. target database is 'Oracle9' detail message is :
unexpect expression: 'TO_CHAR(sysdate, 'MM')'
source sql is :
select to_char(sysdate, 'MM' ) from dual;
//select to_char(sysdate, 'yyyy-MM-dd' ) as a from dual;
为什么报错这个?请大神指教 展开
Caused exception message is: translate sql exception, message is
format sql error. target database is 'Oracle9' detail message is :
unexpect expression: 'TO_CHAR(sysdate, 'MM')'
source sql is :
select to_char(sysdate, 'MM' ) from dual;
//select to_char(sysdate, 'yyyy-MM-dd' ) as a from dual;
为什么报错这个?请大神指教 展开
2015-07-11 · 知道合伙人数码行家
关注
展开全部
1.日期和字符转换函数用法(to_date,to_char)
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual;
//日期转化为字符串
select to_char(sysdate,'yyyy') as nowYear from dual; //获取时间的年
select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的月
select to_char(sysdate,'dd') as nowDay from dual; //获取时间的日
select to_char(sysdate,'hh24') as nowHour from dual; //获取时间的时
select to_char(sysdate,'mi') as nowMinute from dual; //获取时间的分
select to_char(sysdate,'ss') as nowSecond from dual; //获取时间的秒
select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual//
2. select to_char( to_date(222,'J'),'Jsp') from dual
显示Two Hundred Twenty-Two
3. 求某天是星期几
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;
星期一
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual;
monday
设置日期语言
ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';
也可以这样
TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')
4. 两个日期间的天数
select floor(sysdate - to_date('20020405','yyyymmdd')) from dual;
5. 时间为null的用法
select id, active_date from table1
UNION
select 1, TO_DATE(null) from dual;
注意要用TO_DATE(null)
6.月份差
a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd')
那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
所以,当时间需要精确的时候,to_char还是必要的.
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual;
//日期转化为字符串
select to_char(sysdate,'yyyy') as nowYear from dual; //获取时间的年
select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的月
select to_char(sysdate,'dd') as nowDay from dual; //获取时间的日
select to_char(sysdate,'hh24') as nowHour from dual; //获取时间的时
select to_char(sysdate,'mi') as nowMinute from dual; //获取时间的分
select to_char(sysdate,'ss') as nowSecond from dual; //获取时间的秒
select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual//
2. select to_char( to_date(222,'J'),'Jsp') from dual
显示Two Hundred Twenty-Two
3. 求某天是星期几
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;
星期一
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual;
monday
设置日期语言
ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';
也可以这样
TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')
4. 两个日期间的天数
select floor(sysdate - to_date('20020405','yyyymmdd')) from dual;
5. 时间为null的用法
select id, active_date from table1
UNION
select 1, TO_DATE(null) from dual;
注意要用TO_DATE(null)
6.月份差
a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd')
那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
所以,当时间需要精确的时候,to_char还是必要的.
展开全部
会不会是oracle9不支持,我在oracle10下执行
收起 select to_char(sysdate, 'MM' ) from dual
是有结果的,你的源语句具体是什么
收起 select to_char(sysdate, 'MM' ) from dual
是有结果的,你的源语句具体是什么
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
首先在这里给你回答的人都试过了 select TO_CHAR(sysdate, 'MM') from dual; 这个语句处理起来时没问题的。
然后我看到source sql is 后面还有一个//select to_char(sysdate, 'yyyy-MM-dd' ) as a from dual;
是不是这个原因,你把你里面 //换成--试试 或者直接去掉下面这个注释。
然后我看到source sql is 后面还有一个//select to_char(sysdate, 'yyyy-MM-dd' ) as a from dual;
是不是这个原因,你把你里面 //换成--试试 或者直接去掉下面这个注释。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select extract(month from sysdate) from dual;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
SQL> select * from v$version;
BANNER-------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
PL/SQL Release 11.2.0.1.0 - Production
CORE 11.2.0.1.0 Production
TNS for 32-bit Windows: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production
SQL> select to_char(sysdate,'MM') from dual;
TO
--
03
BANNER-------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
PL/SQL Release 11.2.0.1.0 - Production
CORE 11.2.0.1.0 Production
TNS for 32-bit Windows: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production
SQL> select to_char(sysdate,'MM') from dual;
TO
--
03
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询