要实现一个简单的功能,通过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()方法来提交更新数据操作。