java Hibernate与MySQL插入查询不一致
这个问题快把我逼疯了。基本上,我已经设置了一个到java类的hibernate映射。该类将执行插入表的操作。但事实并非如此。开始时,由于超时,我正在锁定Hibernate。第二,它起作用了,然后就不起作用了
仅供参考,我正在使用随附的netbeans 6.9.1和Hibernate 3。和最奇怪的是,当我在调试模式下运行程序时(在调试模式下放置断点,程序从一行到另一行缓慢爬行),我可以得出结论,初始化sessionFactory大约需要5秒钟。这可能是被锁起来的主要原因
我做错了什么?仅供参考,我正在本地主机中使用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 楼答案
首先,取消对源代码的注释以进行事务划分,因此代码中没有定义任何事务。请取消注释
session.getTransaction().begin();
和session.getTransaction().commit();
此外,在finally块中没有必要执行flush()。刷新但此后永不提交意味着刷新期间所做的所有更改都不会保存到数据库中。可以使用
session.setFlushMode()
控制冲洗行为。默认情况下,它是FlushMode.AUTO
,当事务提交时,hibernate将自动执行刷新(session.getTransaction().commit();
),因此您可以删除session.flush();
行此外,一个
SessionFactory
应该代表一个数据库。创建SessionFactory
非常昂贵,但是创建session
非常便宜。因此,您应该创建一个SessionFactory
实例,并使用这个SessionFactory
来创建整个应用程序中的所有Session
Netbean的内置hibernate工具可以创建一个实用程序类来获取单个
SessionFactory
实例。请参阅http://netbeans.org/kb/docs/web/hibernate-webapp.html`