.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
来源:互联网 发布:如何选择电视机 知乎 编辑:程序博客网 时间:2024/05/23 17:41
当我们用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版本上才能正常运行。
- .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
- .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
- setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP)
- setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP)的使用
- 写在hibernate里面的sql setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
- Hibernate 的原生sql查询转map setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP)
- 直接返回查询信息对应的表头信息-----setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
- hibernate setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)
- setResultTransformer
- transformers
- Hibernate原生SQL(createSQLQuery,通过Transformers.ALIAS_TO_ENTITY_MAP设置生成MAP)查询,自动读取ORACLE CLOB内容的解决方案
- 调用play的jpa查询数据时添加Transformers.ALIAS_TO_ENTITY_MAP可将结果集封装到list<map>对象里
- JSON transformers
- Monad transformers
- Hibernate Transformers
- NHibernate SetResultTransformer and DTO
- hibernate (SQLQuery)query.setResultTransformer
- Hibernate 中setResultTransformer使用
- android-NDK学习开发二--HelloWorld
- nginx 配置root运行
- NFS挂载不上时
- 使用rsync完成Linux服务器间同步目录
- 不可不知道国内虚拟化厂商
- .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
- 关于APACHE 无权限访问的问题 403 解决方案
- Ideal education
- Android之gallery
- cygwin完整版下载地址
- CSMA/CD CSMA/CA
- 山寨开机选择四大系统-----------RadioGroup 、RadioButton单选按钮
- 魔术师发牌问题C++实现
- HTTP服务七层架构技术探讨