代码 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. |
|
补充一下HibernateUtil
public class HibernateUtil { public Session getSession(){ Configuration configuration = new Configuration(); configuration.configure(); SessionFactory factory = configuration.buildSessionFactory(); Session session = factory.openSession(); return session; } } 求各位大神帮忙看看 初学者 3Q |
|
打个断点看看有没有执行到
|
|
20分 |
你的代码应该是正确的,原因如下:
一、可能是jar包导入的问题,hibernate版本我用的是hibernate-distribution-3.6.7.Final,同时需要数据库的jar包,你确认下你的项目中少哪个包不,我项目中的jar如下: 二、如果jar包没问题,你需要在hibernate的核心配置中加入如下配置: <property name=”show_sql”>true</property> 然后在次运行您的项目,此时需注意查看控制台有无产生SQL语句,我的运行效果是这样的: 三、如果步骤二中确实发送的sql语句则一般已经操作成功,需核对你打开的表是不是你hibernate配置中链接的表,如果你打开的数据库与项目中配置的不是同一个数据库,那就只能呵呵了 |
我估计也是第三步出现问题了。 |
|
<generator class=”native”></generator>你的user的id属性还没有赋值,赋值以后再试试看。
|
|
不需要为id赋值!该配置表示主键的生成策略,是不需要指定user实例中id属性值的,当提交事务是数据库会自动生成一个id值放在对应的字段里面,id取值需参照: class=”native”每次保存的user实例的id值等于上一个user实例的id值加1,第一个保存进来的user实例的id为1。 |
|
自动增长identity比较多,native |