- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想在oracle11g数据库表中插入记录。我正在从 java 调用存储过程。在执行存储过程时,我收到以下错误。
ORA-01843: not a valid month.
我正在将日期从 String 转换为 Java 中的日期,如下所示
date=new SimpleDateFormat("MM/dd/yyyy").parse(visitDate);
在我的存储过程中,我有以下插入查询
create or replace PROCEDURE CREATE_VISIT(p_visit_date varchar2)
insert into visit(VISIT_ID,visit_date) values
(frc.SEQ_VISIT.nextval,nvl(to_date(p_visit_date, 'mm/dd/yyyy hh:mi am'),
sysdate));
END CREATE_VISIT;
最佳答案
您有一个 Java 中的 String
。您可以将其转换为 Java 中的Date
。到目前为止,想必一切都很好。
但是,您的过程接受 varchar2
。因此,在某些时候,您构造的 Date
会被显式或隐式转换为 varchar2
。您没有说明这是在哪里发生的(在 Java 中还是在 PL/SQL 中),也没有说明它是显式还是隐式完成的。如果转换是在 PL/SQL 中隐式完成的,那么将使用 session 的 NLS_DATE_FORMAT
,对于同一数据库中的不同 session ,该转换可能会有所不同。在基于美国的数据库和客户端的默认安装中,这将是 DD-MON-RR
。
在您的过程中,您可以对使用显式格式掩码传入的字符串调用 to_date
。如果传入的字符串不是 mm/dd/yyyy hh:mi am
格式,您将收到错误,或者更糟糕的是,您将收到不正确的结果(这是老问题是字符串 01/02/03 是否代表 2003 年 1 月 2 日、2003 年 2 月 1 日或 1901 年 2 月 3 日)。
如果我们猜测 Java 中的 Date
使用 session 的默认 NLS_DATE_FORMAT
隐式转换为 varchar2
,即 DD- MON-YYYY
,然后我们就可以看到为什么您的 to_date
转换会失败。例如,如果您的 Date
为 2014 年 5 月 30 日,则会隐式转换为字符串“30-MAY-14”。如果您随后尝试使用 to_date
和格式掩码 mm/dd/yyyy hh:mi am
将其转换回 date
,Oracle会尝试将字符串中的 30 转换为月份并引发错误,因为没有第 30 个月。
实际上,您应该自始至终都使用正确的数据类型,并且应该避免像瘟疫一样的隐式强制转换。如果您将过程声明为采用 date
参数,则可以从 Java 代码中传递 Date
并在过程中省略 to_date
调用。 Date
将从 Java 传递到 PL/SQL,无需转换为 varchar2
,然后再转换回 date
,您就赢了不必担心确保所有格式掩码在整个代码库中保持一致。
create or replace PROCEDURE CREATE_VISIT(p_visit_date date)
AS
BEGIN
insert into visit(VISIT_ID,visit_date)
values (frc.SEQ_VISIT.nextval,nvl(p_visit_date, sysdate);
END CREATE_VISIT;
关于java - ORA-01843 : not a valid month,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24194618/
发现问题 赞比亚的一个项目,主要做主从数据库同步,主库在赞比亚机房,从库在中国青岛阿里云服务器上面,通过Dataguard实现,当运行一段时间后,发现主从数据库的数据不一致了,从库无法启动,报“O
我目前正面临着一堵墙,我正试图从两个不同的表中获取信息,让它们与按计数记录的信息并排显示。一个是第一个表中具有特定值的总金额,第二个是不同列的值。 表A.current与B.id相同 但是我想要的信息
我正在使用数据泵对 4 个 .dmp 文件执行导入并继续接收如下错误集: ORA-39002: invalid operation ORA-39070: Unable to open the log
我的 j2ee Web 应用程序中出现此错误。 java.sql.SQLException: ORA-00604: error occurred at recursive SQL level 1 OR
现场测试工程师在半夜电话反馈:在新建的小测试库做XTTS流程验证,遇到错误: ERROR at line 1:
今天有朋友问到如下一则案例,ORA-01114,ORA-27067以及OSD-04026错误同时出现: *** ACTION NAME:() 2009-04-01 09:31:00.762 ***
> set serveroutput on > set autoprint on; > declare > v_first_name empl
IAM在oracle和数据库中真的是全新的。 非常抱歉提出一个愚蠢的问题。 这是我的问题。我有数据库导出(不是我的数据库,所以我不知道它是如何导出的:有区别吗?),我想用以下脚本导入它: @Echo
这些是我尝试从我的 C# 代码执行存储过程时遇到的错误。 ORA-06502: PL/SQL: numeric or value error: character string buffer too
我们有以下 ORA 错误,它以不同的语言打印错误消息。这种情况很少见,我们将不得不重新启动我们的应用程序服务器。在我的分析中,我发现,在连接到数据库时,JDBC 正在通过采用用户的区域设置在内部更改
刚开始时,有一台服务器的ORACLE 11G数据库连接不上,报错:ORA-12541:TNS:无监听程序 重启服务里面的两个Oracle服务,都没解决。 在网上看到一篇文章说另一种可能是oracle
尝试从客户端使用服务名称 orcl 连接到服务器数据库时出现上述错误.当我使用其他服务名称时它正在连接,即 dms 下面是我的 listener.ora SID_LIST_LISTENER = (
我有一个 Java 类,它调用 SQL 过程来执行一些数据库操作。这是我的 Java 方法: public static void buildContent(String id) throws
下面是我的 SQLPLUS 启动、LSNRCTRL SERVICES、LSNRCTRL STATUS 和 TNSPING 的输出。还包括我的 LISTENER.ORA 文件、TNSNAMES.ORA
我尝试通过运行以下sql来生成一些测试数据。 BEGIN FOR i IN 1..8180 LOOP insert into SPEEDTEST select 'column
当我清楚地识别了变量时,Oracle 不断给我一个无效标识符错误。 //get parameters from the request String custID=request.getPa
我必须在我的应用程序中处理 ORA-28011 和 ORA-28002。但是这些 ORA 警告被 JDBC 抑制了(我认为) 我怎样才能在 Java 中捕获这些? 有什么 JDBC 属性吗? 我不喜欢
当我们通过监听器连接到 Oracle 并达到我们的进程限制时,我们得到一个 ORA-12519:TNS:找不到合适的服务处理程序。查看事件的跟踪文件,它显示 ORA-00020:超过最大进程数 (%s
正如标题所说,我正在尝试使用 sed 来替换,例如, ora.LISTENER_SCAN1.lsnr 1 ONLINE ONLINE myserver1 ora.LISTENER_SCAN2.lsnr
我有一个连接到 Oracle 的 Django 应用程序。每刷新 10 次左右,不管是哪个页面,都会报错。重新启动后的第一次 ORA-03113 和每个后续错误 ORA-03135。 我已经检查了数据
我是一名优秀的程序员,十分优秀!