1. Criteria.list() 查询会把数据放到一级缓存
2. 如果在一个事务里面查询两次,如果两次结果都一样会使用缓存里面的数据
3. 如果两次查询结果不一样,那么一样的部分使用缓存里面的数据,不一样的会重新被缓存
sql打印的问题:
针对上述 2 , 虽然两次的结果都一样,都会查询两次数据库
所以只要调用了 Criteria.list() 方法,一定会访问数据库。然后拿查出来的数据进行对比。
注意: 数据是否一样是通过 primary key 来对比,不关心其他的字段
源码看: org.hibernate.loader.Loader: 1068 行
写个测试例子去调度一下,跟一下就能得到此结果