Hibernate的工作机制

hibernate的常用接口

   (1) Configucation:负责加载Hibernate的配置及映射信息,启动Hibernate,根据连接到数据库的信息来创建SessionFactory

               对象。

   (2) SessionFactory:  初始化Hibernate,创建Session对象。他是线程安全的,通常采用单子模式创建此对象。

   (3)Session :负责保存·修改·删除·查询·加载对象,这个session不是线程安全的,使用Threadlocal来得到session

                           (相当于创建了一个副本)。

   (4)Transaction: 事务处理      开启事务的方法 Transaction tx=  session.beginTransaction();  提交事务 tx.commit();

     (5) Query和Criteria:Query是执行数据库查询,Query接口包装了一个HQL语句,HQL语句是面向对象的,它引用类名

          和属性名,而不是表名和字段名。Criteria完全封装了基于字符串形式的查询语句,比Query接口更加面向对象,擅长

          动态查询。 

  2.hibernate体系结构

          

hibernate原理解析 - song_haipeng1207@126 - ‰じ鹏☆ve的博客

 

 3.hibernate的工作原理

         (1)hibernate如何连接数据库?

              配置文件Hibernate.cfg.xml文件中定义了和数据库进行连接的信息,包括数据库方言.jdbc驱动.用户名.密码和URL等。

             Configuration 类借助dom4j的xml解析器进行xml的解析设置环境,然后使用这些环境属性来生成sessionfactory。这样

             sessionfactory生成的session 就能够成功获得数据库的连接。

         (2)hibernate如何进行数据库写操作?

              当保存一个pojo持久化对象时,触发Hibernate保存事件监听器进行处理。Hibernate通过映射文件获得对象对应的数据库

             表名以及属性对应的数据库列名,然后通过反射机制获得持久化对象的各个属性,最终组织向数据库插入新对象的SQL的

             insert语句。调用session.save()保存数据后这个对象会被标识为持久化状态放在session,当事物进行提交时才真正执行

             insert语句。

         (3)hibernate如何从数据中载入对象?

             当需要读取读取文件时,Hibernate先尝试从session缓存中读取,如果session缓存数据不存在或是脏数据并且配置了二级

            缓存,Hibernate尝试从二级缓存中检索数据;否则Hibernate会根据对象类型·主键等信息组织select语句到数据库中读取,

            再把select结果组织成对象返回。

         (4)hibernate如何进行数据库查询操作?

              Hibernate提供SQL  HQL  Criteria查询方式。HQL是其中运用最广泛的查询方式。用户使用session.createQuery()函数以

              一条HQL语句为参数创建Query查询对象后,Hibernate会使用Anltr库把HQL语句解析成jdbc可以识别的sql语句。如果设置了

              查询缓存,那么执行Query.list()时,Hibernate会先对查询缓存进行查询,如果查询缓存不存在,在使用select语句查询数

             据库。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值