1)引入
factory = new Configuration().configure().buildSessionFactory();
session = factory.openSession();
Transaction tx = session.beginTransaction();
User user1 = (User) session.get(User.class, 1);
User user2 = (User) session.get(User.class, 1);
tx.commit();
结果为:
Hibernate: select user0_.id as id1_7_0_, user0_.name as name2_7_0_ from t_user user0_ where user0_.id=?
说明:由结果可以看出,Hibernate并没有因为执行了两次get查询就执行两次select语句
2)解释
Session中有自己的缓存(也就是Hibernate一级缓存),在执行数据库操作之前,会先检查session缓存中是否有该对象,如果存在,则不再访问数据库,直接取出缓存中的即可。基本原理可以参考下面伪代码:
class Session
{
private Map<Object,id> map;
Object getObject(Class clazz,id)
{
Object obj = map.get(id);
if(null==obj)
{
obj = "select * from xxx where id=?";
map.put(id,obj);
}
return obj;
}
}
3)如果数据库内容在中间改变了,需要立即重新访问数据库,那么就需要使用refresh方法。(refresh方法也就是重新发送一个select语句)
4)另外一个例子
factory = new Configuration().configure().buildSessionFactory();
session = factory.openSession();
Transaction tx = session.beginTransaction();
User user = new User();
user.setName("sky");
session.save(user);
session.save(user);
session.save(user);
结果为:
Hibernate: insert into t_user (name) values (?)
解释:save就是将瞬时状态转化为持久化状态,save的时候,会检查对象是否在缓存中存在,如果不存在在放入缓存,存在则不放入,所以只会有一个insert语句
问题:那么我们如何将相同的对象多次保存到数据库中呢?只能new一个对象保存一次了。