Hibernate 进阶

 

目录

 

hibernate对象的三种状态

瞬时态,持久态,脱管态

三种状态的转化

持久态对象能够自动更新主数据库

hibernate 一级缓存

hibernate一级缓存简介,及作用

一级缓存内部结构(快照区)

hibernate多表查询

sql多表查询

hql多表查询

hibernate二级缓存


hibernate对象的三种状态

瞬时态,持久态,脱管态

瞬时态:new命令刚创建的对象,不存在持久化标识,尚未与hibernate session关联,在数据库中也没有记录。

持久态:持久态对象存在持久化标识,加入到了session的缓存中,并且相关联的session没有关闭,在数据库中有对应的记录。

脱管态:当某个持久态对象与session的关联被关闭时就变成了脱管态,脱管态对象存在持久化标识,与数据库中的数据存在关联,只是失去了去当前session的关联。

具体请看下图:

三种状态的转化

持久态对象能够自动更新主数据库

hibernate 一级缓存

hibernate一级缓存简介,及作用

hibernate一级缓存就是指session缓存,session缓存是一块内存空间,用来存放相互管理的java对象。hibernate在查询对象的时候,首先会在一级缓存中进行查找,如果找到,就直接取出使用,不会再查询数据库;如果没有找到就回去数据库中查找相应数据,查找到的数据也会放置在一级缓存中。。hibernate一级缓存的作用就是减少对数据库的访问次数!

一级缓存内部结构(快照区)

hibernate多表查询

sql多表查询

1、连接查询
     交叉连接:笛卡尔积
     select * from A,B;
     内连接    :inner join (inner 可以省略)
            隐式内连接:
           select * from A,B where A.id = B.aid;
           显示内连接:
           select * from A inner join B on A.id = B.aid;
     外连接    :
            左外连接:left outer join(outer 可以省略)
            select * from A left outer join B on A.id= B.aid;
            右外连接:right outer join(outer 可以省略)
            select * from A right outer join B on A.id = B.aid;
2、子查询

hql多表查询

连接查询
       交叉连接
       内连接
          显示内连接
          隐式内连接
          迫切内连接
       外连接
           左外连接
           右外连接
           迫切左外连接

其实这些查询语法大致是一致的,只是hql查询的是对象,而sql查询的是表,下面来比较一下sql和hql的连接查询

以上说明了hql的内连接,那什么是迫切内连接呢?和内连接由什么区别呢?

内连接:

迫切内连接:

可以看到就差了一个字fetch,其实无论是内连接还是迫切内连接发送到底层的sql都是一样的,打印出来生成的sql也是一样的,并没有fetch关键字(fetch并不是sql语句中的关键字,只能在hql中只用)!生成sql语句后fetch就消失了,fetch到底什么作用呢?

hibernate二级缓存

hibernate二级缓存作用,配置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值