`

Hibernate HQL示例三:属性查询

阅读更多

根据属性查询:

 单个属性查询,返回的结果集属性的列表,其元素和属性的类型一致
 多个属性查询,返回的结果集是数组类型,数组的长度和查询的属性数量相关,数组中元素的类型与相应的属性类型相同

 

示例

package com.bjsxt.hibernate;

import java.util.Iterator;
import java.util.List;

import org.hibernate.Session;

import junit.framework.TestCase;

/**
 * 简单的属性查询
 * @author Administrator
 *
 */
public class SimplePropertyQueryTest extends TestCase {

	/**
	 * 单一属性查询
	 *
	 */
	public void testQuery1() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			
			List students = session.createQuery("select name from Student").list();
			for (Iterator iter = students.iterator();iter.hasNext();) {
				String name = (String)iter.next();
				System.out.println(name);
			}
		}catch(Exception e) {
			e.printStackTrace();
		}finally {
			HibernateUtils.closeSession(session);
		}			
	}
	
	/**
	 * 多个属性的查询
	 *
	 */
	public void testQuery2() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			
			//查询多个属性,其集合元素是对象数组
			//数组元素的类型,跟实体类的属性的类型相关
			List students = session.createQuery("select id, name from Student").list();
			for (Iterator iter = students.iterator();iter.hasNext();) {
				Object[] obj = (Object[])iter.next();
				System.out.println(obj[0] + ", " + obj[1]);
			}
		}catch(Exception e) {
			e.printStackTrace();
		}finally {
			HibernateUtils.closeSession(session);
		}			
	}

	public void testQuery3() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			
			//查询多个属性,其集合元素是对象数组
			//数组元素的类型,跟实体类的属性的类型相关
			//更参见的用法,给对象起个别名,然后通过别名来引用属性值
			List students = session.createQuery("select s.id, s.name from Student s").list();
			for (Iterator iter = students.iterator();iter.hasNext();) {
				Object[] obj = (Object[])iter.next();
				System.out.println(obj[0] + ", " + obj[1]);
			}
		}catch(Exception e) {
			e.printStackTrace();
		}finally {
			HibernateUtils.closeSession(session);
		}			
	}
	
}

 

分享到:
评论

相关推荐

    Hibernate查询语言HQL.PPT

    HQL 的应用示例: * 使用 HQL 检索对象:User user = (User) session.createQuery("from User where id = :id").setParameter("id", userID).uniqueResult(); * 使用 HQL 实现复杂查询:from Cat cat where cat....

    hibernateHQL关联查询

    ### Hibernate HQL 关联查询详解 #### 一、引言 在进行数据库操作时,关联查询是必不可少的一部分,尤其在处理复杂的数据结构时更是如此。Hibernate作为一种流行的Java持久层框架,提供了强大的对象关系映射(ORM...

    Hibernate HQL查询 分页查询 模糊查询.docx

    HQL(Hibernate Query Language)是一种面向对象的查询语言,它允许开发者使用类及其属性来编写查询语句,而不是传统的SQL语句。这使得开发人员能够更加专注于业务逻辑而不用深入到SQL层面。HQL支持各种复杂的查询,...

    hibernate 查询?Hibernate的HQL查询

    2. 简单HQL示例: ```java Query query = session.createQuery("from User user where user.name like 'J%'"); List<User> users = query.list(); ``` 3. 复杂HQL示例: ```java Query query = session....

    Hibernate中的查询:HQL、Criteria、原生SQl

    本篇文章将深入探讨Hibernate中的三种主要查询方式:HQL(Hibernate Query Language)、Criteria API以及原生SQL。 一、HQL(Hibernate Query Language) HQL是Hibernate提供的一种面向对象的查询语言,它类似于SQL...

    HibernateHQL.zip_更新

    此压缩包中的`HibernateHQL.chm`文件很可能是Hibernate HQL的详细教程或参考手册,包含了HQL的语法、用法示例、最佳实践以及可能遇到的问题解决方案。它可以帮助开发者深入理解如何在实际项目中高效地使用HQL进行...

    HQL(Hibernate Query Language):

    Hibernate Query Language(HQL)是Hibernate框架中用于操作对象关系映射(ORM)的一种查询语言。它是面向对象的,设计目的是让开发人员可以使用对象而不是数据库表进行查询,从而简化了与数据库交互的过程。HQL的...

    Hibernate 课件_HQL

    ### Hibernate 课件_HQL 知识点解析 #### HQL查询 ...这些知识点涵盖了HQL的基本概念、查询方法、各种高级查询技巧以及Session的管理等方面,希望能够帮助大家更好地理解和掌握Hibernate的HQL查询技术。

    hibernate hql各类查询范例

    第三个示例中,使用了 `DetachedCriteria` 类来进行更复杂的查询操作。该方法名为 `getGroupMaxSeq`,主要功能是获取指定父组下的最大顺序值。 #### 关键概念解释: - **DetachedCriteria** 是 Hibernate 提供的一...

    hibernateHQL基本查询

    ### Hibernate HQL 基本查询详解 #### 一、HQL 概述 HQL (Hibernate Query Language) 是一种面向对象的查询语言,由 Hibernate 官方提供,用于简化数据库查询过程。与传统的 JDBC 方式相比,使用 HQL 进行数据库...

    Hibernate HQL查询.docx

    ### Hibernate HQL 查询详解 #### 一、HQL 概述 Hibernate 提供了一种非常强大的查询语言——HQL(Hibernate Query Language),它在语法上与 SQL 类似但功能更为强大,因为它支持面向对象的特性,例如继承、多态性...

    Hibernate HQL.txt

    此示例程序首先配置Hibernate并创建`SessionFactory`,然后通过`Session`执行HQL查询,并最终输出查询结果。这只是一个简单的例子,实际应用中可能会涉及更复杂的查询逻辑和数据处理。 总结来说,Hibernate HQL提供...

    HibernateHQL实现前台翻页

    "HibernateHQL实现前台翻页"这一主题就是关于如何利用Hibernate的HQL(Hibernate Query Language)来实现数据库查询的分页功能,并结合Servlet(通常与MVC模式中的Controller层对应)和MySQL数据库来构建一个完整的...

    精通hibernate HQL语言

    HQL,全称Hibernate Query Language,是Hibernate框架提供的一种面向对象的查询语言,它的语法结构与SQL相似,但主要针对对象和实体进行操作,而不是直接操作数据库表。HQL是Hibernate官方推荐的检索数据的主要方式...

    HQL是hibernate自己的一套查询

    根据提供的标题、描述以及部分代码内容,我们可以了解到这段材料主要涉及的是Hibernate框架中的HQL(Hibernate Query Language)查询语言的使用。接下来将详细介绍HQL的相关知识点。 ### HQL概述 HQL是Hibernate...

    Hibernate 多表连接分页查询示范项目

    Hibernate 支持多种方式来实现多表连接查询,包括 HQL(Hibernate Query Language)和 Criteria 查询。本项目主要关注 Criteria API 的使用,这是一种基于 Java 对象的查询方式,更加灵活且易于理解和维护。 **...

    Hibernate教程(数据查询)HQL,PDF格式

    在给定的部分内容中,我们看到了一个简单的Hibernate查询示例: ```java List users = session.find("from User"); ``` 这条语句使用HQL语法查询了所有的`User`对象。`find`方法是`Session`接口的一个快捷方法,...

    hibernate hql where语句拼接工具类

    HQL(Hibernate Query Language)是Hibernate提供的一个SQL的面向对象的查询语言,它使得开发者可以避免直接编写SQL语句,从而更好地进行数据库操作。本文将深入探讨“hibernate hql where语句拼接工具类”,并结合...

    Hibernate_使用示例代码

    7. **查询语言(HQL)**:Hibernate Query Language,允许开发者以面向对象的方式编写查询,类似SQL但更面向对象,如`from User`,`select u from User u where u.name='John'`。 8. **Criteria API**:另一种查询...

    hql模糊查询hql模糊查询

    根据提供的文件信息,本文将详细解析HQL(Hibernate Query Language)中的模糊查询技术,并通过具体的代码示例来阐述不同方式下的实现方法。 ### HQL模糊查询概述 HQL是Hibernate框架提供的一种面向对象的查询语言...

Global site tag (gtag.js) - Google Analytics