hibernte 中执行增删改查 最终由 AbstractEntityPersister类执行
对于在hibernate 配置<mapping package="org.springframework.samples.petclinic.model"/> 只会处理含有
SequenceGenerator和TableGenerator注解的实体
对于save和update操作都会加入相应的ActionQueue中,sessionflush方法会真正执行这些操作
- org.hibernate.sql.ANSIJoinFragment:Mysql的SQL生成类
- org.hibernate.loader.AbstractEntityJoinWalker@initStatementString:Join语句
- org.hibernate.cfg.AnnotationBinder.bindManyToOne:多对一注解(一对一可能被转化为这个)
- org.hibernate.loader.JoinWalker.walkEntityTree:实体解剖全过程
- 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的类