java - 如何在 JPA 中创建一个序列而不直接在数据库中创建它

标签 java database oracle hibernate jpa

我正在做一项服务,该服务使用 JPA 从源获取数据并将它们提取到我的数据库中。 id 是使用序列生成的。 我使用以下命令在我的数据库上创建了序列:

CREATE SEQUENCE crm_test_sq_1 MINVALUE 1 MAXVALUE 999999999999999999999999999 START WITH 1 INCREMENT BY 1 CACHE 100 NOCYCLE

但是,我不知道如何直接从我的代码创建序列。

谁能帮我解决这个问题?非常感谢!

我的模型类,modeltest.java:

    @Entity
    @Table(name = "MODEL_TEST")
    
    @JsonPropertyOrder({ "ID", "CODE", "NAME" })
    @XmlRootElement
    @NamedQueries({
        @NamedQuery(name = "modeltest.getall", query = "SELECT e FROM modelteste"),
        @NamedQuery(name = "modeltest.deleteAll", query = "DELETE FROM modeltest e")})
    public class modeltest implements Serializable {
        private static final long serialVersionUID = 1L;
    
        @Id
        @GeneratedValue(generator = "crm_test_sq", strategy = GenerationType.SEQUENCE)
        @SequenceGenerator(name = "crm_test_sq", sequenceName = "crm_test_sq",allocationSize=1)
        @Column(name="ID", unique=true, nullable=false, precision=10, scale=0)
        private Long id;
    
        @Column(name = "CODE")
        private String isocurrencycode;
    
        @Column(name = "NAME")
        private String currencyname;
    
        public modeltest() {
        }
//........... getter and setter method

我的dao类,modeltestDao.java

public Boolean saveData() {
        
        
//............................................
            getEntityManager().createNamedQuery("modeltest.deleteAll").executeUpdate();
            
            // i want something like below, but obviously this line of code give me an error
            getEntityManager().createNativeQuery ("CREATE SEQUENCE crm_test_sq_1 MINVALUE 1 MAXVALUE 999999999999999999999999999 START WITH 1 INCREMENT BY 1 CACHE 100 NOCYCLE").executeUpdate();
            
        /....................
        return true;
    }

编辑:顺便说一句,为什么我想重置序列是每次我运行服务(将数据提取到数据库中)时,唯一标识符增加了 1。例如,我第一次运行数据时,id 以 1 开头并以 10 结尾,我第二次运行数据时,id 以 11 开头以 20 结尾。此问题仅在我重新启动服务器时停止。

For example:
call saveData() first time
DATA IN TABLE:
ID 1 2 3 4 5
call saveData() second time
DATA IN TABLE:
ID 6 7 8 9 10

其他数据不变,但id。所以我找到了解决这个问题的方法,就是每次运行 saveData() 时删除并重新创建序列

最佳答案

您的提案中有代码味道。为什么首先需要避免序列的数据库缓存?序列的全部意义在于生成唯一标识符,因此您不应在应用程序运行时重新创建序列。

如果您在该方法中创建序列,想象一下当多个线程同时调用该方法时会发生什么。

如果您的用例有效,并且您确实需要删除所有这些记录并重置序列,并且您使用的是 Oracle 12c,则可以执行如下操作:

entityManager.createNativeQuery(
    "ALTER SEQUENCE crm_test_sq_1 RESTART START WITH 1")
.executeUpdate();

关于java - 如何在 JPA 中创建一个序列而不直接在数据库中创建它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36175870/

相关文章:

java - 从 SharedPreference 列表中删除项目 [android]

java - 我的 Java 小程序对其嵌入的图像的访问被拒绝

mysql - 将新数据库导入旧数据库,如何保留旧数据库的值[PHPMyAdmin]

mysql - Laravel 新手和外部 (Moodle) 数据库

sql - 使用两点之间的一组日期(星期日)进行子查询

database - 光标正在返回表中可用的更多数据

java - kafka 0.8.2.2有spring支持吗?

java - 用于关闭 JDialog 的按钮

Android双向sqlite数据库同步

mysql - Update, set + 90 where ...(查询更新错误值)