java - Oracle 序列可以为空吗?

标签 java sql spring oracle sequence-generators

我正在使用 Spring 运行 Java 应用程序,但我的插入语句之一出现错误。我的错误是:

nested exception is java.sql.SQLIntegrityConstraintViolationException: ORA-01400: cannot insert NULL into ("MY_SCHEMA"."VALIDATION_RESULT"."RESULT_SEQ")

对于所有数据库人员来说,是否存在 Oracle 会从 nextval 调用返回 null 的情况?如果多个线程同时调用它怎么办?

对于任何 Spring 开发人员,我们都使用

org.springframework.jdbc.support.incrementer.OracleSequenceMaxValueIncrementer 

处理序列。我们使用 nextLongValue 方法。

我的直觉告诉我 Oracle 没有给我一个 null nextval。从我已经搜索过的所有内容来看,这似乎是不可能的。谁能确认一下吗?

最佳答案

已确认。它们不返回 NULL。您收到一条错误消息。

Oracle 序列实际上生成一个“nextval”对象 block ,以便线程可以快速访问它们。如果存在性能障碍,您可以更改序列以创建更大的预读值。唯一的可能是 Oracle 严重损坏。让您的 DBA 查看警报日志。像 ORA-06nn 错误这样的错误是 DBA 的噩梦,也是我所知道的唯一会真正破坏序列等对象的错误。 在这种情况下,DB(可能还有 DBA)都接近 DOA。这种事情在职业生涯中会发生一次。

我首先会怀疑你的代码。或者有人对序列进行修改——比如用 ALTER SEQUENCE 做一些愚蠢的事情。即,从一开始重新启动序列并打破表约束。当您仅从数据库 DEV 导出表 -> 导入到数据库 TEST 时,也很容易按顺序搞砸事情,因为其他元数据也需要引入。

关于java - Oracle 序列可以为空吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20495128/

相关文章:

java - 在ubuntu上配置eclipse以使用我的jdk版本

java - 如何在不同进程中使用 LocalBroadcastManager 在 Activity 和服务之间进行通信

java - XML 命名空间在 XPath + java 中解析文件时出现问题

php - 在 sql 查询中定义 ORDER

java - 何时何地在 spring-boot 应用程序中应用日志记录

java - 使用 Java 打开终端窗口

sql - 如何在 PostgreSQL 中保存临时 session 变量

MySQL 数据库说明

java - RabbitMQ、docker、单队列、多个消费者

java - 使用 java servlet 重定向响应中丢失 HTTP 自定义 header