当我们用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")可以取值了
分享到:
相关推荐
在 Hibernate 中,createQuery 和 createSqlQuery 是两个常用的查询方法,但是它们之间存在着一些关键的区别。了解这两个方法的差异对于正确地使用 Hibernate 进行数据库操作至关重要。 createQuery 方法 ...
在这个小例子中,我们将探讨如何设置和使用Hibernate进行基本的数据库操作:增加(Insert)、删除(Delete)、修改(Update)和查询(Select)。 首先,我们需要了解Hibernate的核心概念。Hibernate通过XML配置文件...
本文将详细介绍如何利用Hibernate进行多表联合查询,并通过一个具体的例子来展示其强大功能。 #### 二、多表联合查询概述 多表联合查询是指在一个查询语句中同时从两个或两个以上的表中获取数据。在关系型数据库中...
Hibernate支持使用`createSQLQuery`方法创建SQL查询,并返回结果集。例如: ```java Session session = sessionFactory.openSession(); SQLQuery sqlQuery = session.createSQLQuery("SELECT * FROM USER WHERE ...
另一种方法是改用原生的SQL查询,利用Hibernate的`Session.createSQLQuery()`方法来执行,但这可能意味着失去了部分ORM(对象关系映射)的便利性。 然而,如果你坚持使用HQL并且不想采用上述替代方案,你可能会需要...
本文将详细介绍Hibernate的五种查询方式,包括HQL查询、Criteria方法、动态查询DetachedCriteria、例子查询、SQL查询以及命名查询,以满足不同场景下的需求。 1. HQL查询: Hibernate Query Language(HQL)是一种...
- **读取(Read)**: 使用`get()`或`load()`方法根据ID获取实体,或者使用`createQuery()`或`createSQLQuery()`执行HQL(Hibernate Query Language)或SQL查询。 ```java User retrievedUser = session.get(User....
此外,`Session.createQuery()`或`Session.createSQLQuery()`可以用来执行更复杂的HQL(Hibernate Query Language)或原生SQL查询。 6. **事务管理**:在进行多步骤操作时,如同时修改多个记录,需要使用事务确保...
5. **执行查询**:使用Session的createQuery()或createSQLQuery()创建查询,然后执行获取结果集。 6. **事务提交**:完成所有操作后,提交Transaction,所有更改将保存到数据库。 7. **关闭Session**:操作完毕,...
- `createQuery()`/`createSQLQuery()`:执行HQL(Hibernate Query Language)或原生SQL查询。 5. **查询** - HQL是面向对象的查询语言,支持类、属性和关联关系的查询。 - Criteria API提供了一种更面向对象的...
**Hibernate查询方法大全** Hibernate,作为Java领域中最流行的持久化框架之一,提供了多种查询数据的方法。这些方法使得开发者能够高效地从数据库中检索、更新和删除数据,无需编写大量SQL语句。本篇文章将深入...
本文将深入探讨如何在Spring和Hibernate中执行存储过程,并基于描述中的例子进行解析。 首先,让我们了解Spring如何执行存储过程。Spring通过JdbcTemplate或NamedParameterJdbcTemplate提供存储过程的调用。...
5. 查询数据:使用`createQuery()`或`createSQLQuery()`方法编写HQL或SQL查询,然后执行并获取结果集。 6. 更新数据:调用`update()`方法来更新已存在的实体。 7. 删除数据:使用`delete()`方法删除数据库中的记录...
2. 查询数据:`createQuery()`或`createSQLQuery()`方法可以构建HQL或原生SQL查询。通过`list()`、`uniqueResult()`等方法获取查询结果。 3. 更新数据:`update()`方法用于更新对象,`merge()`方法则可以将 ...
### Hibernate SQLQuery 查询Oracle char类型结果为一个字符的解决方法 在使用Hibernate框架结合Oracle数据库进行数据查询时,经常会遇到一个问题:当查询的结果集中包含char类型的字段时,Hibernate可能会将其映射...
例子查询 示例查询是一种简单的查询方式,使用Hibernate的Session对象直接执行SQL语句。示例代码: ```java static void query(String name){ Session s=null; try{ s=HibernateUtil.getSession(); String sql=...
在这个例子中,我们查询了User表中年龄大于18的所有用户,只选择了id和name两个字段。`setParameter`方法用于设置SQL语句中的参数。 为了将查询结果映射到具体的Java对象,我们需要使用`addEntity`或`addScalar`...
使用Session的`get()`或`load()`方法可以查询特定ID的对象,而`createQuery()`或`createSQLQuery()`则支持更复杂的查询。 #### 更新(Update) 当对象的属性发生变化时,调用Session的`update()`方法将更新数据库中...
- **读取(READ)**: `get()`用于根据ID获取对象,`load()`用于延迟加载,`createQuery()`或`createSQLQuery()`用于执行HQL(Hibernate查询语言)或SQL查询。 - **更新(UPDATE)**: 修改对象属性后,调用`update()`...
4. 使用Session对象执行CRUD操作,如:保存(save()或persist())、更新(update())、删除(delete())和查询(createQuery(), createSQLQuery()等)。 5. 提交事务并关闭Session。 **5. HQL(Hibernate Query ...