insert into mytable values('10AUGUST2016年); ////reason not understandable. }% U. W, E& t
此外,我没有在这里使用任何东西TO_DATE函数,我猜隐式转换正在发生? + t1 h% U/ ]- k. c/ Y. e * l7 a! ^3 H/ L1 k# ]; a# G5 ]+ C 解决方案: 7 f) R* x" ~5 p% f5 w" d 字符串到日期转换规则允许额外的格式规则(没有其他修改)。/ L1 }# o7 X5 c A+ N6 q* \ MM也匹配MON和MONTH; 8 B+ T1 m! j3 j, ?% D, ^. JMON匹配MONTH(反之亦然);% F+ Q j" z! u$ n& u
RR匹配RRRR; 和 " W, N6 P2 {7 t) D可选标点符号。所以:2 q# X8 H3 n; B/ H. [
SELECT TO_DATE( '10AUGUST2016','DD-MM-RR ) FROM DUAL UNION ALLSELECT TO_DATE( '10AUGUST2016','DD-MON-RR ) FROM DUAL UNION ALLSELECT TO_DATE( '10AUGUST2016','DD-MONTH-RR' ) FROM DUAL UNION ALLSELECT TO_DATE( '10AUG DD-MM-RR ) FROM DUAL UNION ALLSELECT TO_DATE( '10AUG DD-MON-RR ) FROM DUAL UNION ALLSELECT TO_DATE( '10AUG DD-MONTH-RR' ) FROM DUAL; 6 C* g1 k6 B1 z& v7 y, A
2016年所有生成日期-08-10T00:00:00。 ! p! r/ {5 F" N5 r9 ~. E7 E5 n使用格式模型可以防止这种情况FX2 p$ A. o) b* c6 i
外汇格式准确。本修改符指定函数的字符参数与日期时间格式模型的准确匹配TO_DATE: " l7 a0 d! @" \9 r1 j% }字符参数中的标点符号和引用文本必须与格式模型的相应部分完全匹配(大小写除外)。% J# R' Z# `% M( J9 [ {$ G: |
字符参数不能有多余的空间。如果没有FX,Oracle 会忽略额外的空间。 6 y/ h8 ?7 E4 O& _& M字符参数中的数字数据必须与格式模型中的相应元素具有相同的位数。如果没有FX,前导零可以省略字符参数中的数字。0 Z5 x: I* K' z5 E: v# c0 J+ H 当FX启用时,您可以使用禁用此检查的前导零FM修改为好。6 n8 I z3 ], x5 F5 X3 f* i6 g
如果字符参数的任何部分违反了这些条件中的任何一个, Oracle 将返回错误消息。( W: Y1 a/ n( n! K: [& k
然后: $ T- O }1 [6 o
SELECT TO_DATE( '10-AUGUST-2016','FXDD-MM-RR ) FROM DUAL; . w% \. @8 E; O7 g! z+ m+ T; c5 A
Gives: ORA-01858: a non-numeric character was found where a numeric was expectedand 只能匹配找到精确模式匹配的地方(尽管RR仍会匹配RRRR)。 / x6 U$ p7 i" c7 A, P9 R我猜隐式转换正在发生?5 V" T9 b0 \9 q3 Q
是的,oracle 隐式地TO_DATE( '10AUGUST2016',NLS_DATE_FORMAT )用于转换。 ( d0 U7 j2 d" P4 `' g! X5 h: j若使用: # c K1 }& M# z' s. P
ALTER SESSION SET NLS_DATE_FORMAT = 'FXDD-MM-RR';" `: \( g9 Y @$ o! m- O