hiberntae 信息记录

hibernte 中执行增删改查 最终由 AbstractEntityPersister类执行

对于在hibernate 配置<mapping package="org.springframework.samples.petclinic.model"/> 只会处理含有

SequenceGenerator和TableGenerator注解的实体

对于save和update操作都会加入相应的ActionQueue中,sessionflush方法会真正执行这些操作

  1. org.hibernate.sql.ANSIJoinFragment:Mysql的SQL生成类
  2. org.hibernate.loader.AbstractEntityJoinWalker@initStatementString:Join语句
  3. org.hibernate.cfg.AnnotationBinder.bindManyToOne:多对一注解(一对一可能被转化为这个)
  4. org.hibernate.loader.JoinWalker.walkEntityTree:实体解剖全过程
  5. org.hibernate.loader.OuterJoinableAssociation:外连接类

hibernate 初始化

1:Configuration configuration=new Configuration().configure();

没有指定配置文件默认找classpath下面的hibernate.cfg.xml,找到并且解析配置文件,解析property标签放入

properties对象里面,然后再解析其他的。

 

 

2:SessionFactory sessionFactory= configuration.buildSessionFactory();

注册各种服务jdbcServices,jdbcServices等服务,还有其他的必须属性,

jdbcServices在初始化时,会根据配置文件初始化ConnectionProvider,ConnectionProvider是数据库连接提供者,有几种实现有连接池的c3po,DriverManagerConnectionProviderImpl,假如没有配置ConnectionProvider默认是DriverManangerConnectionProvider。

 

 

3:Session session= sessionFactory.openSession();

新创建一个SessionImpl  session要手动关闭。

 

 

4:

Session session=sessionFactory.openSession();

重新创建一个sessionimpl

Session session=sessionFactory.getCurrentSession();

 会从根据sessionFactory 从 threadlocal(当前线程)找存在的session。

getCurrentSession创建的线程会在事务回滚或事物提交后自动关闭,而openSession必须手动关闭

 

 

 

5:Transaction transaction= sessionFactory.getCurrentSession().beginTransaction();

TransactionCoordinator 设置connection autocommit 为false;

 

:6: session.get();

先从一级缓存取在从二级缓存最后数据库,

一级对象其实就是一个HashMap里面存了对象。

 

 

7:session.load();

延延迟加载返回代理对象,真正需要属性时查询数据库

8: save(),update,saveOrUpdate

save()方法很显然是执行保存操作的,如果是对一个新的刚new出来的对象进行保存,自然要使用这个方法了,数据库中没有这个对象。

update()如果是对一个已经存在的托管对象进行更新那么肯定是要使用update()方法了,数据中有这个对象。

saveOrUpdate()这个方法是更新或者插入,有主键就执行更新,如果没有主键就执行插入。

 

区别:对于一个从托管状态到瞬态的对象(对于一个从数据库中取出来又被删除的对象),这个对象本身是有主键的,但是因为被删除了,所以这个时候因为数据库中已经没有了这条记录了。不过它还有主键存在,所以这个时候不可以使用update()或者是saveOrUpdate(),因为update()方法是认为数据库中肯定有这条记录的,而saveOrUpdate的执行过程就是先查看这个对象是不是有主键,有主键那么就执行update()方法,没有主键就执行save()方法,因此结果跟调用了update()方法的效果是一样的,结果就会出错,因为这个对象已经被删除了,数据库中已经没有这条记录了,只是它还有主键而已(仅仅是存在于内存中),因此这个时候要执行的是save()方法。

 

 

8update的作用上边说了,这里说一下merge的
如果session中存在相同持久化标识(identifier)的实例,用用户给出的对象覆盖session已有的持久实例 
(1)当我们使用update的时候,执行完成后,会抛出异常 
(2)但当我们使用merge的时候,把处理自由态的po对象A的属性copy到session当中处于持久态的po的属性中,执行完成后原来是持久状态还是持久态,而我们提供的A还是自由态

 

 

9:clear和evcit的区别
clear完整的清除session缓存
evcit(obj)把某个持久化对象从session的缓存中清空

 

10:关于hibernate解析sqL 先EntityLoader 到EntityJoinWalker 到Select 分装Sql的类

 

 

 

 

 

 

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值