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;
为什么报错这个?请大神指教
展开
 我来答
day忘不掉的痛
2015-07-11 · 知道合伙人数码行家
day忘不掉的痛
知道合伙人数码行家
采纳数:62646 获赞数:223940
本人担任公司网络部总经理多年,有充足的网络经验、互联网相关知识和资讯。

向TA提问 私信TA
展开全部
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还是必要的.
wucui2007ah
2013-03-13 · TA获得超过120个赞
知道小有建树答主
回答量:159
采纳率:0%
帮助的人:126万
展开全部
会不会是oracle9不支持,我在oracle10下执行
收起 select to_char(sysdate, 'MM' ) from dual
是有结果的,你的源语句具体是什么
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
flamingcy
2013-03-13 · 超过21用户采纳过TA的回答
知道答主
回答量:71
采纳率:0%
帮助的人:62万
展开全部
首先在这里给你回答的人都试过了 select TO_CHAR(sysdate, 'MM') from dual; 这个语句处理起来时没问题的。
然后我看到source sql is 后面还有一个//select to_char(sysdate, 'yyyy-MM-dd' ) as a from dual;
是不是这个原因,你把你里面 //换成--试试 或者直接去掉下面这个注释。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
华夏日长兴
2013-03-13 · TA获得超过9592个赞
知道大有可为答主
回答量:6305
采纳率:85%
帮助的人:3724万
展开全部
select extract(month from sysdate) from dual;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友69c7c72
2013-03-13 · 超过19用户采纳过TA的回答
知道答主
回答量:53
采纳率:0%
帮助的人:49.9万
展开全部
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
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式