打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Hibernate的createSQLQuery查询的小例子
当我们用HQL进行子查询的时候,如select * from Tree where pid in (select id from Tree,此时HIBERANTE就会报错,说什么*号错误之类的。但如果将*改为Tree类里的所有子段时就不会有问题了。就会像平时一样第一行数据返回一个Object[],然后你再根据Tree类里字段对Object[]数组里的值进行转换。这样一来比较麻烦。今天发现如果我SQL来查有一个方法可以返回一个对象的。
Java代码  
  1. Configuration config = new Configuration().configure();  
  2. SessionFactory sf     = config.buildSessionFactory();  
  3. Session session = sf.openSession();  
  4. Transaction ts = session.beginTransaction();  
  5. Query query = session.createSQLQuery("select * from Tree t where pid in (select id from Tree) ").addEntity(Tree.class); //返回对象  
  6. 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必须与数据库中的字段名一模一样。


还可以用作函数方面的。如
Java代码  
  1. Query query = session.createSQLQuery("select sum(id) SUMID from Tree t where pid in (select id from Tree)  
  2. .addScalar("SUMID",Hibernate.INTEGER)  //转换类型,按DB中的type转  
  3. .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); //返回一个map,KEY:为DB中  

名称一致(大小写一致)

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


还有一点就是这个方法在Hibernate3.2版本上才能正常运行。
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
巧用SQLQuery中的addScalar
hibernate原生SQL查询,返回值映射到MAP
使用Hibernate SQLQuery执行原生SQL
Hibernate sql查询
Hibernate Native SQL Example
Hibernate4实战 之 第三部分:Hibernate的基本开发
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服