初学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.

...全文
476 7 打赏 收藏 转发到动态 举报
写回复
用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配置中链接的表,如果你打开的数据库与项目中配置的不是同一个数据库,那就只能呵呵了
【特征工程是什么?】 身高不同的两人,比较体重毫无意义, 但是如果将身高体重加以计算,转化成了BMI指数:BMI=体重/(身高^2) 通过比较这个新创造的特征值,谁胖谁瘦就一目了然了。 这就是特征工程,将原始数据转换为可以更好的、代表预测模型潜在问题的特征,通过分析这个新的特征,可以得到更准确的预测结果。 【特征工程——Python数据分析必备】 脏数据的“清洗剂” 有人说:学会了Python语言,就会做数据分析? 不一定! 你拿到的数据样本集,有可能存在这些问题: 如果样本数据存在问题,对数据建模的执行效率会有很大影响,甚至可能会造成模型结果的偏差。 不懂特征工程,数据分析=白忙一场! 【站内首门!特征工程全解课程】 过去,数字化是企业优化的要点; 而今,数字化成为了企业活下去的关键。 而数据分析应用有多广,特征工程的学习需求就有多大。 不过,大部分课本对于特征工程这一知识点鲜有提及,市面上的课程也少之又少,导致很多人在实际工作或学习中,遇到问题束手无策,严重降低效率。 CSDN全站首发——Python数据处理与特征工程 课程聚焦数据科学中,数据清洗与分析前的特征提取过程,解决数据科学中最重要的原始数据清洗和特征提取。 【定制课程 精准扫除学习盲点】 课程充分考虑各类实际问题,将每个知识点融入到对应的代码实例中,初学者也可无压力上手,讲师手把手带领入门。 知识点扫盲 + 案例实践 + 线上答疑 扫清数据分析前的所有障碍,提升你的数据工作的效率与准确度。 如果你是: 在这里你可以收获...... 了解如何将各类型数据载入计算机,进而愉快的探索数据科学; 掌握如何将需要分析的数据转化为算法模型可以接受的格式; 学会特征提取最基本的处理方式,为后续的算法学习打好基础。 经过19节课程的学习,你可以基本掌握数据采集、读取以及清洗的方法,具备进一步学习数据分析乃至深度学习的能力,能够大大拓宽你日后的求职道路。 【三重福利  惊喜等你】

67,513

社区成员

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

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