Hibernate保存对象

        要实现一个简单的功能,通过Hibernate来向mysql数据库中插入一条记录,即要将一个对象持久化到数据库中。通过查阅发现Hibernate的Session对象有个save()方法可以解决上面的需求。

public void add(Music music) {
		Session session = sessionFactory.openSession();
		try {
			session.save(music);
		} finally {
			session.close();
		}
	}

 调用这个方法时,Hibernate没有报任何异常,也没有打印SQL语句,数据库里没有增加记录,尝试了几次数据库依旧没有增加任何记录。后来通过查阅资料发现需要增加一条语句

session.flush();

 但是当通过HQL语句进行更新数据操作的时候不需要调用session.flush()方法就可以提交

	public void update(Music music) {
		Session session = sessionFactory.openSession();
		try {
			session
					.createQuery(
							"update Music as music set music.name=:name where music.id=:id  ")
					.setParameter("name", music.getName())
					.setParameter("id", music.getId()).executeUpdate();
		} finally {
			session.close();
		}
	}

 因为只是更新部分字段的值,所以采用了HQL语句这样的方式,使用session.update()方法是更新整个对象除了Id的所有属性值,使用update()和save()一样需要flush()方法来提交更新数据操作。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值