MySQL插入查询的Hibernate不一致

时间:2011-03-11 16:44:45

标签: java hibernate jsf netbeans java-ee

这个问题让我疯了。基本上,我已经设置了一个hibernate映射到java类。该类将插入表中。但那并没有发生。一开始,由于超时,我正在锁定Hibernate。其次它工作,然后它没有工作。

有关您的信息,我使用的是随附的netbeans 6.9.1和Hibernate 3。而且......最奇怪的是,当我在调试模式下运行程序时,(其中你放置了断点,程序慢慢地从一行到另一行爬行)我可以得出结论,初始化sessionFactory需要大约5秒钟。可能这是被锁定的主要原因。

我做错了什么? Fyi,我在本地主机中使用LAMPP for mysql。

这是Hibernate配置XML

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
  <session-factory>
    <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
    <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
    <property name="hibernate.connection.url">jdbc:mysql://localhost/rainbow</property>
    <property name="hibernate.connection.username">root</property>
    <property name="hibernate.connection.password">password</property>
    <mapping resource="hibernate.hbm.xml"/>
  </session-factory>
</hibernate-configuration>

这是映射xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
  <class name="datamap.Course" table="app_crs_info">
      <id name="id" column="ID" type="string"/>
      <property name="courseName" type="string">
          <column name="COURSE_NAME"/>
      </property>
      <property name="description" type="string">
          <column name="DESCRIPTION"/>
      </property>
      <property name="level" type="integer">
          <column name="LEVEL"/>
      </property>
  </class>
</hibernate-mapping>

这是映射的类:

public class Course {
    private String id;
    private String courseName;
    private String description;
    private int level;

    /**
     * @return the id
     */
    public String getId() {
        return id;
    }

    /**
     * @param id the id to set
     */
    public void setId(String id) {
        this.id = id;
    }

    /**
     * @return the courseName
     */
    public String getCourseName() {
        return courseName;
    }

    /**
     * @param courseName the courseName to set
     */
    public void setCourseName(String courseName) {
        this.courseName = courseName;
    }

    /**
     * @return the description
     */
    public String getDescription() {
        return description;
    }

    /**
     * @param description the description to set
     */
    public void setDescription(String description) {
        this.description = description;
    }

    /**
     * @return the level
     */
    public int getLevel() {
        return level;
    }

    /**
     * @param level the level to set
     */
    public void setLevel(int level) {
        this.level = level;
    }
}

这就是我所说的:

public void registerCourse(String id, String description,
                                String name, String level) {
       session = null;
       crashLog = new CrashLog();


        try {

            SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
            session = sessionFactory.openSession();
            //session.getTransaction().begin();

            Course course = new Course();
            course.setId(id);
            course.setCourseName(name);
            course.setDescription(description);
            course.setLevel(Integer.parseInt(level));
            session.save(course);
            //session.getTransaction().commit();
        } catch (Exception ex) {
            crashLog.writeToLog(CourseData.class.getName() + "Error : " + ex.toString());
        } finally {
            session.flush();
            session.close();
        }


    }

任何想法的人?

1 个答案:

答案 0 :(得分:0)

首先,您取消注释源以进行事务划分,因此代码中没有定义事务。请取消注释第session.getTransaction().begin();行和session.getTransaction().commit();

此外,没有必要在finally块中执行flush()。刷新但从不提交之后意味着在刷新期间所做的所有更改都不会保存到数据库中。可以使用session.setFlushMode()来控制刷新行为。默认情况下,它是FlushMode.AUTO,当提交事务(session.getTransaction().commit();)时,hibernate将自动执行刷新,因此您可以删除行session.flush();

此外,一个SessionFactory应代表一个数据库。创建SessionFactory代价很高,但创建session非常便宜。因此,您应该创建一个SessionFactory实例,并使用此单SessionFactory在整个应用程序中创建所有Session

Netbean的内置hibernate工具可以创建一个实用程序类来获取单个SessionFactory实例。请参阅http://netbeans.org/kb/docs/web/hibernate-webapp.html

上的Creating the HibernateUtil.java Helper File

enter image description here

`