hibernate - EntityManager 不写入数据库

标签 hibernate jpa hsqldb entitymanager

我刚刚建立了一个到目前为止仍然非常小的项目 maven/jpa/hibernate 项目,我试图在其中持久化一个对象。

我的类(class)是一个非常简单的类(class):

@Entity
public class Person {
    @Id @GeneratedValue
    private int id;
    private String name;
}

我的 persistence.xml 也非常基础:
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
    version="2.0">
    <persistence-unit name="Fahrplan_v2">
        <class>model.Person</class>
        <properties>
            <property name="hibernate.connection.driver_class" value="org.hsqldb.jdbcDriver" />
            <property name="hibernate.connection.url" value="jdbc:hsqldb:file:data/db/db" />
            <property name="hibernate.connection.username" value="sa" />
            <property name="hibernate.connection.password" value="" />
            <property name="hibernate.dialect" value="org.hibernate.dialect.HSQLDialect" />
            <property name="hibernate.hbm2ddl.auto" value="update" />
        </properties>
    </persistence-unit>
</persistence>

最后这里是我用来持久化对象的代码:
EntityManager em = entityManagerFactory.createEntityManager();
em.getTransaction().begin();
em.persist(person);
// em.flush(); <- does not effect outcome.
em.getTransaction().commit();
em.close();

现在我希望在这里发生两件事:首先,我希望创建 Person 表(由于 hibernate.hbm2ddl.auto=update)。这发生过一次,并且正确地写出
CREATE MEMORY TABLE PUBLIC.PERSON(
    ID INTEGER GENERATED BY DEFAULT AS IDENTITY(START WITH 1) NOT NULL PRIMARY KEY,
    NAME VARCHAR(255)
)

但我根本无法重现。每次我启动我的程序时,都会创建 hsqldb 数据库文件,但没有创建表。

其次,我希望持久化对象存储在数据库中,但事实并非如此。此外,手动创建数据库架构并不能解决问题,所以这不是导致问题的原因。持久代码运行时没有任何异常或输出中的任何警告,一切看起来都很好。但是对象只是没有到达数据库。使用“from Person”查询实体管理器时也找不到该对象。

然而,查询似乎是唯一有效的方法。我可以手动将数据插入数据库,“来自人员”查询将成功检索它。

那么,关于我在这里做错了什么的任何提示?

最佳答案

添加 axtavt 的好答案并阐明您的 sleep(1000) 是如何工作的:对于需要绝对同步持久性的开发情况,请关闭默认的 write_delay。

 <property name="hibernate.connection.url" 
      value="jdbc:hsqldb:file:data/db/db;shutdown=true;hsqldb.write_delay_millis=0"/>             

这意味着在将结果返回给调用者之前,每个语句都会写入磁盘。自然,在正常操作中,您可以增加此值。默认为 500 毫秒,需要 sleep(1000)。给出的信息适用于 HSQLDB 2.2.x 版。

关于hibernate - EntityManager 不写入数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8105618/

相关文章:

java - Spring roo Hibernate更新入口多对多映射

java - Hibernate 未在不同架构上创建新列

java - 更改Hibernate中一对多单向关系中的外键约束名称

java - 如何使用数据库管理器调用 Hsqldb 中的过程?

java - hsqldb 数据库锁获取失败

java - Spring Autowiring 仅扫描测试文件

java - 如何处理 spring jpa @transactional 和 catch block 中的新插入

java - 支持用于测试/生产的不同 JPA 生成类型

mysql - sql 查询在 mysql 中工作正常,但在 HSQL 中失败,并在 spring-boot 测试中出现 BadSqlGrammarException

java - hql 查询中的日期格式