setResultTransformer(Transformers.ALIAS_TO_ENTITY_

.setResultTransformer(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];将每一行的内容变换为一个对象了。session

另还能够返回一个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时就能够ide

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

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


还能够用做函数方面的。如 
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中名称一致(大小写一致)
spa

直接就map.get("SUMID")能够取值了orm

本站公众号
   欢迎关注本站公众号,获取更多信息