初学hibernate save()方法添加不进数据也不报错

J2EE 码拜 9年前 (2015-05-10) 2484次浏览 0个评论

代码

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如下:
初学hibernate  save()方法添加不进数据也不报错
二、如果jar包没问题,你需要在hibernate的核心配置中加入如下配置:
<property name=”show_sql”>true</property>
然后在次运行您的项目,此时需注意查看控制台有无产生SQL语句,我的运行效果是这样的:
初学hibernate  save()方法添加不进数据也不报错
三、如果步骤二中确实发送的sql语句则一般已经操作成功,需核对你打开的表是不是你hibernate配置中链接的表,如果你打开的数据库与项目中配置的不是同一个数据库,那就只能呵呵了
引用 2 楼 liangtu33 的回复:

打个断点看看有没有执行到

引用 3 楼 liuhePPPP 的回复:

你的代码应该是正确的,原因如下:
一、可能是jar包导入的问题,hibernate版本我用的是hibernate-distribution-3.6.7.Final,同时需要数据库的jar包,你确认下你的项目中少哪个包不,我项目中的jar如下:
初学hibernate  save()方法添加不进数据也不报错
二、如果jar包没问题,你需要在hibernate的核心配置中加入如下配置:
<property name=”show_sql”>true</property>
然后在次运行您的项目,此时需注意查看控制台有无产生SQL语句,我的运行效果是这样的:
初学hibernate  save()方法添加不进数据也不报错
三、如果步骤二中确实发送的sql语句则一般已经操作成功,需核对你打开的表是不是你hibernate配置中链接的表,如果你打开的数据库与项目中配置的不是同一个数据库,那就只能呵呵了

我估计也是第三步出现问题了。

<generator class=”native”></generator>你的user的id属性还没有赋值,赋值以后再试试看。
引用 5 楼 longweiwen88 的回复:

<generator class=”native”></generator>你的user的id属性还没有赋值,赋值以后再试试看。

不需要为id赋值!该配置表示主键的生成策略,是不需要指定user实例中id属性值的,当提交事务是数据库会自动生成一个id值放在对应的字段里面,id取值需参照: class=”native”每次保存的user实例的id值等于上一个user实例的id值加1,第一个保存进来的user实例的id为1。

引用 6 楼 liuhePPPP 的回复:
Quote: 引用 5 楼 longweiwen88 的回复:

<generator class=”native”></generator>你的user的id属性还没有赋值,赋值以后再试试看。

不需要为id赋值!该配置表示主键的生成策略,是不需要指定user实例中id属性值的,当提交事务是数据库会自动生成一个id值放在对应的字段里面,id取值需参照: class=”native”每次保存的user实例的id值等于上一个user实例的id值加1,第一个保存进来的user实例的id为1。

自动增长identity比较多,native
会根据底层数据库的能力,从identity、sequence、hilo中选择一个,灵活性更强,但此时,如果选择sequence或者hilo,则所有的表的主键都会从Hibernate默认的sequence或者hilo表中取。并且,有的数据库对于默认情况主键生成测试的支持,效率并不是很高
     对于 oracle 采用 Sequence 方式,对于MySQL 和 SQL Server 采用identity(自增主键生成机制),native就是将主键的生成工作交由数据库完成,hibernate不管


CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明初学hibernate save()方法添加不进数据也不报错
喜欢 (0)
[1034331897@qq.com]
分享 (0)

文章评论已关闭!