代码
Session session = new HibernateUtil().getSession();
Transaction transaction = session.beginTransaction();
try {
session.save(user);
transaction.commit();
} catch (Exception e) {
e.printStackTrace();
transaction.rollback();
}finally{
session.close();
}
//以上代码封装在insertUser(User user)方法中 下面调用
User user = new User();
user.setUserName("rose");
user.setPassWord("123");
dao.insertUser(user);
配置文件hibernate_cfg.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="connection.url">
jdbc:mysql://127.0.0.1:3306/hibernate_db
</property>
<property name="connection.username">root</property>
<property name="connection.password">password</property>
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<mapping resource="com/jer/bean/User_hbm.xml" />
</session-factory>
</hibernate-configuration>
配置文件User_hbm.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="com.jer.bean.User" table="usertbl">
<id name="id" column="id">
<generator class="native"></generator>
</id>
<property name="userName" column="userName"></property>
<property name="passWord" column="passWord"></property>
</class>
</hibernate-mapping>
测试运行结果 没报错但数据库中也没添加数据 我试过save 后 flush 也不行
log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment).
log4j:WARN Please initialize the log4j system properly.
------解决思路----------------------
你的代码应该是正确的,原因如下:
一、可能是jar包导入的问题,hibernate版本我用的是hibernate-distribution-3.6.7.Final,同时需要数据库的jar包,你确认下你的项目中少哪个包不,我项目中的jar如下:
二、如果jar包没问题,你需要在hibernate的核心配置中加入如下配置:
<property name="show_sql">true</property>
然后在次运行您的项目,此时需注意查看控制台有无产生SQL语句,我的运行效果是这样的:
三、如果步骤二中确实发送的sql语句则一般已经操作成功,需核对你打开的表是不是你hibernate配置中链接的表,如果你打开的数据库与项目中配置的不是同一个数据库,那就只能呵呵了