zoukankan      html  css  js  c++  java
  • Transformers.ALIAS_TO_ENTITY_MAP,openSession,getCurrentSession

    在比较openSession和getCurrentSession这两个方法之前

    我们先认识一下这两个方法。

    在进行配置信息管理时,我们一般进行一下简单步骤:

    Configuration cfg = new Configuration(); // 获得配置信息对象
    SessionFactory sf = cfg.configure().buildSessionFactory(); //解析并建立Session工厂


    1. Session session = sf.getCurrentSession(); // 获得Session

    2. Session session = sf.openSession(); // 打开Session

    对于上述的两个方法,有以下区别:

    1. openSession 从字面上可以看得出来,是打开一个新的session对象,而且每次使用都是打开一个新的session,假如连续使用多次,则获得的session不是同一个对象,并且使用完需要调用close方法关闭session。

    2. getCurrentSession ,从字面上可以看得出来,是获取当前上下文一个session对象,当第一次使用此方法时,会自动产生一个session对象,并且连续使用多次时,得到的session都是同一个对象,这就是与openSession的区别之一,简单而言,getCurrentSession 就是:如果有已经使用的,用旧的,如果没有,建新的。

    注意:在实际开发中,往往使用getCurrentSession多,因为一般是处理同一个事务(即是使用一个数据库的情况),所以在一般情况下比较少使用openSession或者说openSession是比较老旧的一套接口了;

    对于getCurrentSession 来说,有以下一些特点:

    1.用途,界定事务边界

    2.事务提交会自动close,不需要像openSession一样自己调用close方法关闭session

    3.上下文配置(即在hibernate.cfg.xml)中,需要配置:

    <property name="current_session_context_class">thread</property>

    (需要注意,这里的current_session_context_class属性有几个属性值:jta 、 thread 常用 , custom、managed 少用 )

    a).thread使用connection 单数据库连接管理事务

    b).jta (Java transaction api) Java 分布式事务管理 (多数据库访问),jta 由中间件提供(JBoss WebLogic 等, 但是tomcat 不支持)

    Transformers.ALIAS_TO_ENTITY_MAP

    当我们用HQL进行子查询的时候,如select * from Tree where pid in (select id from Tree,此时HIBERANTE就会报错,说什么*号错误之类的。但如果将*改为Tree类里的所有子段时就不会有问题了。就会像平时一样第一行数据返回一个Object[],然后你再根据Tree类里字段对Object[]数组里的值进行转换。这样一来比较麻烦。今天发现如果我SQL来查有一个方法可以返回一个对象的。
    Configuration config = new Configuration().configure();
    SessionFactory sf     = config.buildSessionFactory();
    Session session = sf.openSession();
    Transaction ts = session.beginTransaction();
    Query query = session.createSQLQuery("select * from Tree t where pid in (select id from Tree) ").addEntity(Tree.class); //返回对象
    List  list = query.list(); 

    此时在遍历list时就可以(Tree)list.get[i];将每一行的内容变换为一个对象了。

    另还可以返回一个Map对象,也就是说在在list里包含多个Map,代码如下
    Query query = session.createSQLQuery("select id,name from Tree t where pid in (select id from Tree) ").setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); //返回一个map,KEY:为DB中名称一致(大小写一致)遍历list时就可以

    Map map = (Map)list.get[i];

    map.get("id");map.get("name");来取值。按你的SQL语句select后的字段名来作为map的Key,但这个key必须与数据库中的字段名一模一样。


    还可以用作函数方面的。如
    Query query = session.createSQLQuery("select sum(id) SUMID from Tree t where pid in (select id from Tree)
    .addScalar("SUMID",hibernate.INTEGER)  //转换类型,按DB中的type转
    .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); //返回一个map,KEY:为DB中名称一致(大小写一致)

    直接就map.get("SUMID")可以取值了


    还有一点就是这个方法在Hibernate3.2版本上才能正常运行。 

  • 相关阅读:
    对象接口
    final关键字
    面向对象----多态,抽象,接口
    面向对象中的继承、封装、构造与析构函数
    PHP类与对象
    JS项目
    AppStore IAP 客户端校验代码
    Android线程计时器实现
    Cocos2d-x java 通过jni调用c++的方法
    ios7 uuid的获取方法
  • 原文地址:https://www.cnblogs.com/Jonecmnn/p/6816956.html
Copyright © 2011-2022 走看看