数据未使用hibernate插入,但没有出错?

时间:2010-12-13 16:35:06

标签: java hibernate

我正在尝试使用Hibernate,但由于某些原因无法插入数据。它似乎工作正常,因为没有给出错误,但是当我检查数据库时表是空的。我不认为它与数据库本身的连接失败,因为当我在映射xml中将表名更改为非超级表时,Hibernate会动态创建它(但正如我所说,没有插入数据) 。有谁知道问题可能是什么?

这是我的代码:

hibernate.cfg.xml中:

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
    <session-factory>
          <property     name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
          <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/intex</property>
          <property name="hibernate.connection.username">root</property>
          <property name="hibernate.connection.password"></property>
          <property name="hibernate.connection.pool_size">10</property>
          <property name="show_sql">true</property>
          <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
          <property name="hibernate.hbm2ddl.auto">update</property>
          <!-- Mapping files -->
          <mapping resource="intex.hbm.xml"/>
    </session-factory>
</hibernate-configuration>

我的映射xml:

<hibernate-mapping>
  <class name="com.intex.uni.courses.Course" table="course">
   <id name="id" column="id" >
   <generator class="increment"/>
  </id>

  <property name="name" column="name" />
  <property name="description" column="description" />
  <property name="url" column="url" />
  <property name="code" column="code" />
 </class>
</hibernate-mapping>

我的测试客户:

public class HibernateTest {

    public static void main(String[] args) {

        Session session = null;

        try {
            SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
            session = sessionFactory.openSession();
            Course course = new Course();
            course.setDescription("Description");
            course.setName("NAME");
            course.setUrl("http://www.url.com");
            session.save(course);
        } catch (Exception e) {
            System.out.println(e.getMessage());
        } finally {
            session.flush();
            session.close();
        }
    }
}

我真的希望有人能够帮助我!在此先感谢:)

5 个答案:

答案 0 :(得分:5)

我怀疑系统没有提交包含所需插入的事务。我总是明确设置交易,例如Hibernate Getting Started Tutorial Example 2.5

另一种方法是您应该能够在代码中设置Hibernate的提交模式,以便隐含事务 - 查看FlushMode

答案 1 :(得分:5)

在主类中使用此代码并进行测试。

Session session = null;
Transaction txn = null;
try {  
    SessionFactory sessionFactory = 
        new Configuration().configure().buildSessionFactory();
    session = sessionFactory.openSession();  
    txn = session.beginTransaction();
    Course course = new Course();  
    course.setDescription("Description");
    course.setName("NAME");
    course.setUrl("http://www.url.com"); 
    session.save(course); 
    txn.commit();

} catch (Exception e) { 
    System.out.println(e.getMessage());
} finally {
    if (!txn.wasCommitted()) {
        txn.rollback();
    }

    session.flush();  
    session.close();   
}

答案 2 :(得分:0)

请尝试以下代码:

public class HibernateTest {

    public static void main(String[] args) {

        Session session = null;
        Transaction txn = null;
        try {
            SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
            session = sessionFactory.openSession();
            txn = session.beginTransaction();
            Course course = new Course();
            course.setDescription("Description");
            course.setName("NAME");
            course.setUrl("http://www.url.com");
            session.save(course);
            txn.commit();
        } catch (Exception e) {
            System.out.println(e.getMessage());
        } finally {
            session.flush();
            session.close();
        }
    }
}

答案 3 :(得分:0)

请在保存之前启动事务并在保存后提交事务。

答案 4 :(得分:0)

检查映射文件是否定义了任何生成器。评论生成器并检查。 这个解决方案对我有用。