`
失落丶神话
  • 浏览: 7149 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Hibernate使用Criteria查询

阅读更多

1、Hibernate使用Criteria查询所有列:

// 声明会话对象
Session ses = null;
try {
	// 获得会话
	ses = HibernateUtil.getSession();
	//获得Criteria对象
	Criteria cri = ses.createCriteria(Emp.class);
	// 使用eq查询empno等于7369的员工信息
	// cri.add(Restrictions.eq("empno", 7369));
	// 使用ideq查询,ideq会根据表的主键查询
	// cri.add(Restrictions.idEq(7369));
	// 使用like查询,MatchMode值:anywhere(匹配任何位置)、start(匹配开头)、end(匹配末尾)
	// cri.add(Restrictions.like("ename", "L",MatchMode.ANYWHERE));
	// 和like功能类似,不过ilike忽略大小写
	// cri.add(Restrictions.ilike("ename", "d",MatchMode.END));
	// 查询年薪大于1500的员工,ge:大于等于、le:小于等于、gt:大于、lt;小于
	// cri.add(Restrictions.gt("sal", 1500f));
	// 查询员工编号等于7369或者7839的员工
	cri.add(Restrictions.or(Restrictions.eq("empno", 7369),
			Restrictions.idEq(7839)));
	// 获得Emp集合
	List<Emp> list = cri.list();
	// 输出Emp集合
	for (Emp e : list) {
		System.out.println(e.getEname() + "\t" + e.getSal());
	}
} catch (HibernateException e) {
	e.printStackTrace();
} finally {
	// 关闭会话
	if (ses != null) {
		HibernateUtil.closeSession();
	}
}

 2、查询单列

public class Test3 {
	/**
	 * Hibernate 使用Criteria查询单列 Projections
	 */
	public static void main(String[] args) {
		// 声明会话对象
		Session ses = null;
		try {
			// 获得会话
			ses = HibernateUtil.getSession();
			//获得Criteria对象
			Criteria cri = ses.createCriteria(Emp.class);
			
//			//查询员工的个数
//			cri.setProjection(Projections.count("empno"));	
//			//查询有年终福利员工的个数,重复设置Projection会覆盖,而不是叠加
//			cri.setProjection(Projections.count("comm"));	
//			
//			Integer count = (Integer) cri.uniqueResult();
//			System.out.println(count);
			
			//增加查询的列
			cri.setProjection(Projections.property("ename"));
			//追加条件,相当sql增加的where语句
			cri.add(Restrictions.idEq(7369));
			
			//获得查询结果,返回List
			List<String> objs = cri.list();
			
			for(String s : objs){
				System.out.println(s);
			}
		} catch (HibernateException e) {
			e.printStackTrace();
		} finally {
			// 关闭会话
			if (ses != null) {
				HibernateUtil.closeSession();
			}
		}
	}
}

 3、查询多列

public class Test4 {
	/**
	 * Hibernate 使用Criteria查询多列 Projections.projectionList().add
	 */
	public static void main(String[] args) {
		// 声明会话对象
		Session ses = null;
		try {
			// 获得会话
			ses = HibernateUtil.getSession();
			// 获得Criteria对象
			Criteria cri = ses.createCriteria(Emp.class);

			//同时统计员工总数和有福利的员工总数
			//相当于sql:select count(empno),count(comm) from emp
//			cri.setProjection(Projections.projectionList()
//			.add(Projections.count("empno"))
//			.add(Projections.count("comm")));
			
			
			//查询所有员工的部门编号和姓名
			//相当于sql:select deptno,ename from emp
			cri.setProjection(Projections.projectionList()
					.add(Projections.property("deptno"))
					.add(Projections.property("ename")));
			//追加条件
			//相当于sql:select deptno,ename from emp where empno = 7369
			cri.add(Restrictions.idEq(7369));
			// 返回list,每一条记录都是一个Object对象数组,每一列是Object对象
			List<Object[]> list = cri.list();

			for (Object[] objs : list) {
				System.out.println(objs[0] + "\t" + objs[1]);
			}
		} catch (HibernateException e) {
			e.printStackTrace();
		} finally {
			// 关闭会话
			if (ses != null) {
				HibernateUtil.closeSession();
			}
		}
	}
}

 

分享到:
评论

相关推荐

    hibernateCriteria查询

    ### Hibernate Criteria 查询详解 #### 一、概述 Hibernate Criteria 查询是一种强大的对象化查询方式,它为开发者提供了一种灵活而直观的方式来构建复杂的查询逻辑。与传统的SQL查询相比,Criteria查询更加面向...

    Hibernate的Criteria用法总结.doc

    使用 Criteria 进行查询,主要要清晰的是 Hibernate 提供了那些类和方法来满足开发中查询条件的创建和组装。Criteria crit = session.createCriteria(User.class); crit.add(Restrictions.eq("name", "John")); List...

    Hibernate中Criteria的完整用法

    使用 Criteria 进行查询,主要要清晰的是 Hibernate 提供了那些类和方法来满足开发中查询条件的创建和组装。通过 Criteria,可以根据实际情况灵活地组装查询条件,以满足复杂的查询需求。 Hibernate 的 Criteria 是...

    Hibernate-Criteria_模糊查询

    在深入探讨Hibernate与Criteria结合进行模糊查询之前,我们先来了解一下Hibernate和Criteria的基本概念,以及为何选择使用它们进行模糊查询。 ### Hibernate简介 Hibernate是一个开放源代码的对象关系映射(ORM)...

    hibernate如何使用criteria联合查询 group by 的语句

    这个案例是根据分组查询,并且得到每组的条数,不懂得可以q我:1710086675,欢迎认识更多新朋友

    Hibernate-Criteria 模糊查询

    在Hibernate中,`Criteria`接口支持使用`Expression`类及其子类来实现模糊查询。例如,使用`like`表达式来进行模糊匹配: ```java Criteria criteria = session.createCriteria(User.class); criteria.add...

    Hibernate的Criteria用法总结

    在Java持久层框架Hibernate中,Criteria API是一种动态构建SQL查询的方法,它允许开发者在运行时构建查询,提供了更面向对象的查询方式。本篇将详细阐述Hibernate Criteria API的使用。 首先,Criteria API由...

    Hibernate中Criteria的使用

    Hibernate 中 Criteria 的使用 Hibernate 中 Criteria 的使用是 ...Hibernate 中 Criteria 的使用可以灵活地根据查询条件的组装来进行查询,使用 Criterion 和 Projection 设置查询条件,可以实现复杂的查询操作。

    Hibernate_Criteria条件查询数据

    本资料主要关注的是Hibernate中的Criteria查询,这是一种灵活且强大的查询机制,允许程序员以编程方式构建SQL查询。 Criteria查询是Hibernate提供的API,与传统的HQL(Hibernate Query Language)查询相比,它更...

    Hibernate中,利用Criteria查询容器实现sql的写法

    在Java的持久化框架Hibernate中,Criteria API是一种用于构建动态查询的强大工具,它允许开发者以对象化的方式构建SQL语句,而无需直接编写SQL代码。本篇将详细讲解如何在Hibernate中利用Criteria查询来实现类似SQL...

    Hibernate中Criteria的完整用法.docx

    例如,创建一个 Criteria 实例 org.hibernate.Criteria 接口表示,可以使用 Criteria 的 add(Criterion criterion) 方法来添加查询条件。Criterion 可以使用 Restrictions 工具类来创建,例如使用 eq、ge、between ...

    Hibernate Criteria 排序的問題

    ### Hibernate Criteria 排序问题详解 #### 一、前言 在使用Hibernate进行数据库操作时,经常...通过掌握这些知识点,开发者可以更加灵活高效地使用Hibernate Criteria API来进行数据查询和排序操作,提高开发效率。

    Hibernate中Criteria的用法

    Hibernate 中 Criteria 的用法是 Hibernate 框架中的一种查询机制,它提供了灵活的查询方式,可以根据不同的条件进行查询。Criteria 查询机制主要包括 QBE(Query By Example)、QBC(Query By Criteria)和 HQL...

    Hibernate的Criteria文档

    在Java的持久层框架Hibernate中,Criteria API是一个强大的查询工具,它可以用来替代传统的SQL或HQL(Hibernate Query Language)查询,以实现更加面向对象的数据库交互。Criteria API的设计旨在屏蔽不同数据库之间...

    关联映射hibernate的criteria的用法

    与HQL(Hibernate Query Language)相比,Criteria API更易于理解和使用,尤其在处理复杂的查询条件时。它通过对象来表示查询条件,使得代码更具有可读性和可维护性。 ### 2. 创建Criteria查询 首先,我们需要从`...

    Hibernate criteria基本操作

    Hibernate Criteria 是一种在Java应用程序中使用Hibernate ORM框架执行SQL查询的方式。它提供了一种面向对象的方式来构建查询,使得代码更加可读和易于维护。Criteria API 提供了多种方法来构建复杂的查询,包括添加...

    Hibernate中Criteria的用法详解

    在Java的持久化框架Hibernate中,Criteria API是一个强大的查询工具,它可以用来构建动态和复杂的查询。Criteria API的主要优点在于它的灵活性,允许开发者在运行时构建查询,而不必预先定义HQL(Hibernate Query ...

Global site tag (gtag.js) - Google Analytics