【1】INSERT INTO ORDERS
VALUES (1000,1005,'31-MAR-03','02-APR-03','1201 ORANGE AVE', 'SEATTLE', 'WA', '98114');
为什么老是提示输入的为无效的月份呢?
OrderDate DATE, ShipDate DATE
'31-MAR-03','02-APR-03'
字段是date类型, 无法对你的字符串进行隐式转换, 使用显示转换(to_date)或是
修改当前session的日期格式为dd-mon-yy(nls_date_format)
关于nls_date_format:
同一个参数可以在不同地方设置,其中session的优先级最高,也就是说,如果在系统环境变量中设置了,但是在alter session set ....中又
设置了,对当前session来讲,以alter session 设置的生效。
【2】(转)
工作中碰到用spool导出数据,其中有日期格式的字段,因为format了各列,就不想用to_char把日期再format了,而且用to_char的话还要把要
所有的列都写在select语句中。win下默认的格式为DD-MM-yy ,如下:
SQL>select sysdate from dual;
SYSDATE
----------
21-12月-04
数据库中的日期字段中的格式为yyyy-mm-dd hh24miss,导出的数据中也要这样的格式,设置nls_date_format就可以实现,如下:
1.用alter session来修改
SQL>alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';
SQL> select sysdate from dual;
SYSDATE
-------------------
2004-12-21 14:44:24
2.在OS中设置nls_date_format
打开一个控制台窗口
C:>SET NLS_DATE_FORMAT=YYYY-MM-DD HH24:MI:SS //注意:这里YYYY-MM-DD HH24:MI:SS不能加引号,但在unix系统中要加
SQL> select sysdate from dual;
SYSDATE
-------------------
2004-12-21 14:45:44
这样改了以后只对当前的控制台窗品有效,如果不想每次都设置,就修改系统/用户环境变量,新增一个nls_date_format变量,值为YYYY-MM-DD
HH24:MI:SS
打开一个控制台窗口
SQL> select sysdate from dual;
SYSDATE
-------------------
2004-12-21 14:46:15
这样在spool中直接select * from tabs就行了。
【3】
附:oracle日期格式参数 含义说明
d: 一周中的星期几
day: 天的名字,使用空格填充到9个字符
dd: 月中的第几天
ddd: 年中的第几天
dy: 天的简写名
iw: ISO标准的年中的第几周
iyyy: ISO标准的四位年份
yyyy: 四位年份
yyy,yy,y: 年份的最后三位,两位,一位
hh: 小时,按12小时计
hh24: 小时,按24小时计
mi: 分
ss: 秒
mm: 月
mon: 月份的简写
month: 月份的全名
w: 该月的第几个星期
ww: 年中的第几个星期