hibernate 学习 五 hibernate核心接口

一 Configuration接口

  Configuration对象只存在于系统的初始化阶段。配置相关。

  配置文件可以使用默认的路径,也可以指定路径。

  Configuration config = new Configuration().configure()  

  SessionFactory sessionfactory = Config.buildSessionFactory()

  也可以使用new Configuration().setProperty()的方式动态配置属性

二 SessionFactory接口

  通常一个应用程序只有一个SessionFactory实例,主要用来生成session对象。

  但是,当项目中要操作多个数据库时,则必须为每一个DB指定一个SessionFactory。

  Hibernate中sessionFactory相当于一个缓冲区,hibernate自动生成的SQL,映射数据,数据库配置,以及某些可重复利用的数据可以存放在换出去中,这是hibernate的二级缓存。

  SessionFactory是线程安全的,他的一个实例可以多个线程共享。   

  OpenSession():  调用时创建一个新的,用完后,要手动关闭,使用Close

  GetCurrentSession(): 创建一个实例,并绑定到当前线程,在提交或失败回滚后自动关闭。

OpenSession用的比较少,一般都使用GetCurrentSession();

                                  必须在hibernate.cfg.xml中配置事务。

                  <session-factory>
                   <!-- Put other elements here -->
                   <property name="hibernate.current_session_context_class">thread/JTA</property>
               </session-factory>
JDBC事务和JATA事务的区别
    JDBC的一切行为包括事务是基于一个Connection的,在JDBC中是通过Connection对象进行事务管理。在JDBC中,常用的和事务相关的方法是:
setAutoCommit、commit、rollback等。JDBC为使用Java进行数据库的事务操作提供了最基本的支持。通过JDBC事务,我们可以将多个SQL语句放到同一个事务中,
保证其ACID特性。JDBC事务的主要优点就是API比较简单,可以实现最基本的事务操作,性能也相对较好。但是,JDBC事务有一个局限:
一个 JDBC 事务不能跨越多个数据库!!!所以,如果涉及到多数据库的操作或者分布式场景,JDBC事务就无能为力了。
JTA:分布式事务

三 Session接口

  session对象的生命周期以Transaction对象的事务开始和结束为边界。

  对象的三个状态:(1)瞬时态; (2)持久态; (3)游离态;

  save() : 将对象加入缓存; 生成唯一标识; 生成insert语句

  update(): 将对象加入缓存; 生成update语句;

  saveOrUpdate():

  delete():

  get(): 先从一级缓存查,如果没有则越过二级缓存,查DB; 无论Class元素的lazy属性是什么,都直接返回实体类;  不存在时返回NULL; 不延迟加载

  load(): 先一级缓存,再二级缓存;当Class元素的lazy属性是false时,会返回持久化对象的代理类实例;  不存在返回异常; 延迟加载

  contains():

  evict() :  清空缓存;

  clear() :清空缓存

  createQuery(): HQL

  createCriteria():

  createSQLQuery( ):SQL

  createFilter()          

四 Transaction接口

  管理事务的接口;

  事务:为了避免数据不完整,不一致;

  事务的ACID:原子性, 一致性,持久性,隔离性(可串行性)。

  不完全的事务隔离会导致如下问题:

          更新丢失:

           脏数据:

           不可重复读:

           幻读:

  隔离级别:  

      读操作未提交:可以读取事务的中间状态(读取未提交的数据), 脏读,不可重复读,幻读

           读操作已提交:不能读取未提交的事务;   不会脏读, 但是可以不可重复读,幻读;

            可重读:保证能读取相同的数据不会丢失,不会脏读,不会不可重复读;但是会幻读;

       可串行化:最严格;

   hibernate可以对事务进行配置:本地事务  或者  全局事务;  还可以对隔离级别进行设置(8-串行化; 4-可重复读;2-读已提交; 1:读未提交);

  常用方法

    commit():

    rollback(): 

五 Query接口

  HQL ,  QBC, SQL 三种查询的方式;

   HQL: 不是引用表名和字段名,而是引用类名和属性名。

   setter():设置HQL中的参数;参数有两种表示:     一是用名称:  是  “:参数名”(这种方式更容易阅读);  二是用:?

    list(): 将所有结果集中的数据转换为java对象,占很大空间,浪费;

    iterator():  把使用到的数据才转成java对象;但是必须顺序读取。

    uniqueResult() : 返回唯一的结果;

   executeUpdate() :

    setFirstResult()

   setMaxResult() :

   实体查询:  String    hql = "from Users as U";

属性查询:   “select name,age from User”

                          "slect new User(name, age) from User"

  HQL 聚集函数:

  HQL分组和排序:

  HQL子查询:

六 Criteria接口

  更加面向对象的查询方式

 

上一篇:通过Dapr实现一个简单的基于.net的微服务电商系统(十五)——集中式接口文档实现


下一篇:hibernate(五)核心开发接口与对象的三种状态