1

我正在使用 H2 使用 Hibernate 开发一个简单的 java 应用程序。

我没有收到任何例外。Hibernate 输出和 H2 的跟踪文件向我显示了数据的插入。

但是数据不存储在数据库中。hibernate 和 H2 控制台都不显示任何插入的数据。

也许有人有一个想法。

谢谢

这是我的休眠配置:

<hibernate-configuration>
  <session-factory>
    <property name="hibernate.dialect">org.hibernate.dialect.H2Dialect</property>
    <property name="hibernate.connection.driver_class">org.h2.Driver</property>
    <property name="hibernate.connection.url">jdbc:h2:~/HibTest;TRACE_LEVEL_FILE=3;FILE_LOCK=NO</property>
    <property name="hibernate.connection.username">sa</property>
    <property name="hibernate.connection.password"></property>

    <property name="hibernate.hbm2ddl.auto">create-drop</property>

    <mapping package="de.test.hib.domain" />
    <mapping class="de.test.hib.domain.Data" />
  </session-factory>
</hibernate-configuration>

这是我的域类:

package de.test.hib.domain;

import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.SequenceGenerator;


@Entity
@SequenceGenerator(sequenceName="SEQ_DATA",name="SEQ_DATA_GEN",initialValue=1)
public class Data implements Serializable {

    private static final long serialVersionUID = 1L;

    private Integer id;
    private String content;

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (id != null ? id.hashCode() : 0);
        return hash;
    }

    @Override
    public boolean equals(Object object) {
        if (!(object instanceof Data)) {
            return false;
        }

        Data other = (Data) object;
        if ((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))) {
            return false;
        }

        return true;
    }

    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE,generator="SEQ_PERSON_GEN")
    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    @Column(nullable=false)
    public String getContent() {
        return content;
    }

    public void setContent(String content) {
        this.content = content;
    }
}

以及持续的过程:

Transaction trans = HibernateUtils.getInstance().getCurrentSession().beginTransaction();
HibernateUtils.getInstance().getCurrentSession().saveOrUpdate(this);
HibernateUtils.getInstance().getCurrentSession().flush();
trans.commit();
4

1 回答 1

0

FILE_LOCK=NO从数据库 URL 中删除该选项。这是非常危险的,因为这意味着数据库文件不受保护。如果数据库已经打开,那么以这种方式打开数据库会损坏数据库文件。

于 2013-03-06T20:14:43.720 回答