hibernate:
是对jdbc的封装,是一种数据访问层的框架技术
优势:
可以直接访问数据库,不需要编写sql和java,可以统一写java对数据进行访问
以前变量的赋值拼接不方便,并且查出来的值还要传入resultset还得再传入java集合
跨平台,用hibernate可以统一配置好各种数据库
怎么用:
1 导入包
2 hbm.cfg.xml中配置好session-Factory
中的数据库连接信息
3 session-factory相当于jdbc 通过getSession获取连接
------
hibernate 缓存机制
内存 : cpu不能直接操作硬盘数据,先把硬盘中数据放到内存中
缓存也是内存的一部分,针对每个数据,第二次访问时,第一回访问内存
如果存有此数据,对于第二回来说,第一回的数据时缓存
获取时:session.get(T.class,1);
session.load(T.class,1);
区别:get查询不到可以返回一个null值,load查询不到会报异常,一般都使用get
用缓存的优点:
1 减少了数据库的访问次数
2 提高代码的执行效率
3 一级缓存是默认开启的
一级缓存:
1 hibernate创建session (连接会话)时,每个session分配一个空间,
用于保留第一回查询到的数据,第二回查此数据时,就用到缓存
session不是jsp那个httpSession
hibernate中的session是一次连接会话
含封装的增删改查操作数据的方法
2 是用session管理
当session open时 , 缓存就打开
当session close时,缓存就关
当第一次加载数据后,之后的多次加载是基于缓存的
开发时,session一般都是open
//验证缓存的存在,使用同一个Session查同一条数据两次,
//如果第二回没有输出hql,说明缓存是存在
//一级缓存是Session是独享的
//通过两个独立的session访问同一数据,如果出现两回HQL说明一级缓存独享
二级缓存:
1 以缓存中的数据来查看数据
2 通过SessionFactory来管理
二级缓存是随着SessionFactory的打开而打开的,关闭而关闭
3 可通过id来查询缓存中的数据
设置class-cache
再通过query-cache去查询
4 二级缓存是属于进程范围的缓存
序列控制
或者
acc_seq