public void testClear(){ Configuration cfg=new AnnotationConfiguration(); SessionFactory sf=cfg.configure().buildSessionFactory(); Session session=sf.openSession(); session.beginTransaction(); Teacher teacher=(Teacher)session.load(Teacher.class, 1); System.out.println(teacher.getName()+" "+teacher.getTitle()); //session.clear();//加了就清除缓存 Teacher teacher2=(Teacher)session.load(Teacher.class, 1); System.out.println(teacher2.getName()+" "+teacher2.getTitle()); session.getTransaction().commit(); session.close(); sf.close(); }根据Load只在请求时发出sql语句的原理,按理说hibernate应该发出两条语句,但是发现只发出来一条sql语句,原因就是get和load首先从缓存中查找信息,如果缓存中没有,才去数据库中查找信息。本例中ID号为1的属性在缓存中已经存在,Load无需再向数据库查询。如果在中间加clear方法,清除缓存中的信息,那就要发出两条sql去查询了。
2.flush方法:可以强制进行从内存到数据库的同步!
public void testFlush(){ Configuration cfg=new AnnotationConfiguration(); SessionFactory sf=cfg.configure().buildSessionFactory(); Session session=sf.openSession(); session.beginTransaction(); Teacher teacher=(Teacher)session.load(Teacher.class, 1); teacher.setZhicheng(ZhiCheng.B); //session.flush();//强制缓存中的内容与数据库同步 teacher.setZhicheng(ZhiCheng.C); System.out.println(teacher.getName()+" "+teacher.getTitle()); session.getTransaction().commit(); session.close(); sf.close(); }只发出来一条Sql语句,是在commit时发出的。你在commit之前就算改一百次,最后只是在commit才会跟新,原因是你一直在缓存里面修改,hibernate并没有在commit之前将缓存中的数据与数据库中的数据同步。加了flush方法之后,就会强制缓存中的内容与数据库同步。
find相当于select,去取出对象,但是已经过时。
转载请注明出处:http://blog.csdn.net/acmman