java.sql.BatchUpdateException : ORA-00001: unique constraint while we generating primary key

标签 java sql hibernate jdbc

我正在使用 Oracle 数据库。我们经常看到对我们服务的调用失败。当我查看日志时,我在表中看到以下异常

java.sql.BatchUpdateException:ORA-00001:唯一约束

我们实现了主键生成。

请找到代码

<class name="com.dvo.History" table="HISTORY" >
        <id name="hiId" type="java.lang.Long">
            <column name="HI_ID" precision="22" scale="0" />
           <generator class="com.radiant.cisms.hibernate.generator.SequenceGenerator">      
                <param name="TABLE_NAME">HISTORY</param>
            </generator>
        </id>

类文件

package com.generator;

import java.io.Serializable;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Properties;

import org.apache.log4j.Logger;
import org.hibernate.HibernateException;
import org.hibernate.MappingException;
import org.hibernate.dialect.Dialect;
import org.hibernate.engine.SessionImplementor;
import org.hibernate.id.Configurable;
import org.hibernate.id.IdentifierGenerator;
import org.hibernate.type.Type;


public class SequenceGenerator implements IdentifierGenerator, Configurable {


    private static Logger logger = Logger.getLogger(SequenceGenerator.class);

    String tableName;

    public void configure(Type arg0, Properties arg1, Dialect arg2)throws MappingException {
        tableName = arg1.getProperty("TABLE_NAME");
    }


    public Serializable generate(SessionImplementor arg0, Object arg1)throws HibernateException {
        return getNextValue(arg0);
    }


    public Serializable getNextValue(SessionImplementor session){
        Long nextValue = null;
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;
        try{
            Connection connection = session.connection();
            preparedStatement = connection.prepareStatement("SELECT SEQ_GENERATOR_VALUE FROM SEQ_GENERATOR WHERE SEQ_GENERATOR_TABLE = ?");
            preparedStatement.setString(1, tableName);
            resultSet = preparedStatement.executeQuery();
            while(resultSet.next()){
                nextValue = resultSet.getLong("SEQ_GENERATOR_VALUE");
            }
            resultSet.close();
            preparedStatement.close();
            preparedStatement = connection.prepareStatement("UPDATE SEQ_GENERATOR SET SEQ_GENERATOR_VALUE = ? WHERE SEQ_GENERATOR_TABLE = ?");
            preparedStatement.setLong(1, nextValue+1);
            preparedStatement.setString(2, tableName);
            preparedStatement.executeUpdate();
        } catch(SQLException e){
            logger.debug(e.getMessage());
        } catch(Exception e){
            logger.debug(e.getMessage());
        }
        finally{

            try{
                resultSet.close();
                preparedStatement.close();
            } catch(SQLException e){
                logger.debug(e.getMessage());
            }
        }
        return nextValue;
    }

}

我们正在用 oracle 序列替换此代码

最佳答案

将同步添加到您的 getNextValue 方法。

 synchronized public Serializable getNextValue(SessionImplementor session)

测试并让我知道结果应该有效。

关于java.sql.BatchUpdateException : ORA-00001: unique constraint while we generating primary key,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26688747/

相关文章:

sql - JOIN 打破 WHERE 子查询

java - Spring/H2/Hibernate FORMATDATETIME "unexpected token: ' yyyy.MM.dd'"

mysql - Hibernate 按位运算函数未注册

java - 如何在Java应用程序中设置H2嵌入式数据库以在小型网络中使用?

java - 绘制透明路径

java - 如何防止程序删除方法中的最后一个索引

sql - SINGLE_NCLOB 需要一个 UNICODE (widechar) 输入文件

sql - SQL 中 where 子句的顺序重要吗?

java - libgdx 0.9.7 actor hit 不接收 actor 系统坐标

hibernate - Spring 和 Hibernate 事务