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()方法来提交更新数据操作。

猜你喜欢

转载自blog-chen-lian.iteye.com/blog/2347595
今日推荐