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

Wonderful_jerry 2015-04-26 10:39:29
代码
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.

...全文
506 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
longweiwen88 2015-05-04
  • 打赏
  • 举报
回复
引用 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。[/quote] 自动增长identity比较多,native 会根据底层数据库的能力,从identity、sequence、hilo中选择一个,灵活性更强,但此时,如果选择sequence或者hilo,则所有的表的主键都会从Hibernate默认的sequence或者hilo表中取。并且,有的数据库对于默认情况主键生成测试的支持,效率并不是很高 对于 oracle 采用 Sequence 方式,对于MySQL 和 SQL Server 采用identity(自增主键生成机制),native就是将主键的生成工作交由数据库完成,hibernate不管
longweiwen88 2015-04-28
  • 打赏
  • 举报
回复
<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。
liangtu 2015-04-26
  • 打赏
  • 举报
回复
打个断点看看有没有执行到
Wonderful_jerry 2015-04-26
  • 打赏
  • 举报
回复
补充一下HibernateUtil
public class HibernateUtil {
	public Session getSession(){
		Configuration configuration = new Configuration();
		configuration.configure();
		SessionFactory factory = configuration.buildSessionFactory();
		Session session = factory.openSession();
		return session;
	}
}
求各位大神帮忙看看 初学者 3Q
callmedarcy 2015-04-26
  • 打赏
  • 举报
回复
引用 2 楼 liangtu33 的回复:
打个断点看看有没有执行到
引用 3 楼 liuhePPPP 的回复:
你的代码应该是正确的,原因如下: 一、可能是jar包导入的问题,hibernate版本我用的是hibernate-distribution-3.6.7.Final,同时需要数据库的jar包,你确认下你的项目中少哪个包不,我项目中的jar如下: 二、如果jar包没问题,你需要在hibernate的核心配置中加入如下配置: <property name="show_sql">true</property> 然后在次运行您的项目,此时需注意查看控制台有无产生SQL语句,我的运行效果是这样的: 三、如果步骤二中确实发送的sql语句则一般已经操作成功,需核对你打开的表是不是你hibernate配置中链接的表,如果你打开的数据库与项目中配置的不是同一个数据库,那就只能呵呵了
我估计也是第三步出现问题了。
  • 打赏
  • 举报
回复
你的代码应该是正确的,原因如下:
一、可能是jar包导入的问题,hibernate版本我用的是hibernate-distribution-3.6.7.Final,同时需要数据库的jar包,你确认下你的项目中少哪个包不,我项目中的jar如下:

二、如果jar包没问题,你需要在hibernate的核心配置中加入如下配置:
<property name="show_sql">true</property>
然后在次运行您的项目,此时需注意查看控制台有无产生SQL语句,我的运行效果是这样的:

三、如果步骤二中确实发送的sql语句则一般已经操作成功,需核对你打开的表是不是你hibernate配置中链接的表,如果你打开的数据库与项目中配置的不是同一个数据库,那就只能呵呵了

67,549

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧