1.hql更新 String hql = "update PhUser set realName=?"; int row=this.getSession().createQuery(hql).setString(0, "小李想").executeUpdate(); PhUser 类名 2.hql删除 String hql = "delete PhUser a where a.userId=2"; int row=this.getSession().createQuery(hql).executeUpdate(); 还有个这种的格式: final String hql = "delete PhRoleFunction as a where a.roleId = " + roleId; this.getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { return session.createQuery(hql).executeUpdate(); } });更新也可以写成这样的格式 3.hql单表查询 String hql = "from PhUser a where a.userId=" + userId; List list = this.getHibernateTemplate().find(hql); 4.hql多表查询 (1)String hql = "select new map(a.CUId as CUId,a.unitName as unitName,b.CUFId as CUFId,b.UFName as UFName) from PhCorrelativeUnit a,PhCorrelativeUnitFunction b where a.CUId=b.CUId"; List list = this.getHibernateTemplate().find(hql); 多个表的字段放到map中,map的键值就是as后面的别名,如果没有as就是字段名 (2) String hql = "select new com.phantom.appeal.action.bean.DealPaper(a.id as id,a.billId as billId,a.state as state,a.creator as creator,a.createtime as createtime ,b.eventContent as eventContent ,c.realName as realName,b.billCode as billCode,b.citName as citName ) from PhDealBill a,PhAcceptBill b,PhUser c where a.departmentId="+ billid+ " and a.state=0 and a.billId=b.billId and a.creator =c.userId order by a.billId"; return this.getHibernateTemplate().find(hql); 另外就是写一个类,对应你要查询的字段,这里的类名是new com.phantom.appeal.action.bean.DealPaper,里面对应查询的字段名 5.得到记录数 String hql = "select count(*) from PhUser"; List list = this.getHibernateTemplate().find(hql); return ((Long) list.get(0)).intValue();
|
五种检索方式的使用场合和特点:
HQL : 是面向对象的查询语言,同SQL有些相似是Hib中最常用的方式。 查询设定各种查询条件。 支持投影查询,检索出对象的部分属性。 支持分页查询,允许使用having和group by 提供内制的聚集函数,sum(),min(),max() 能调用用户的自定义SQL 支持子查询,嵌入式查询 支持动态绑定参数 建议使用Query接口替换session的find方法。 Query Q = session.createQuery("from customer as c where c.name = :customerName" + "and c.age = :customerAge"); query.setString ("customerName" , "tom"); query.setInteger("customerAge" , "21"); list result = query.list(); QBC : QBCAPI提供了另一种方式,主要是Criteria接口、Criterion接口和Expression类 Criteria criteria = session.createCriteria(customer.class); Criterion criterion1 = Expression.like("name","t%"); Criterion criterion2 = Expression.eq("age",new Integer(21)); Critera = criteria.add(criterion1) ; Critera = criteria.add(criterion2) ; list result = criteria.list(); 或是: list result = session.createCriteria(Customer.class).add(Expression.eq("this.name","tom")).list(); SQL : 采用HQL和QBC检索时,Hib生成SQL语句适用所有数据库。 Query query = session.createSQLQuery("select {c.*} from customers c where c.name like : customername " + "and c.age = :customerage","c",customer.calss); query.setString("customername","tom"); query.setInteger("customerage","21"); list result = query.list(); /////////////多态查询 HQL :session.createQuery("from employee"); QBC :session.createCriteria(employee.class); HQL : session.createQuery("from hourlyEmployee"); QBC : session.createCriteria(hourlyEmployee.class); 下面的HQL查询语句将检索出所有的持久化对象: from java.lang.Object ; from java.io.serializable ; ////////////查询的排序 1'查询结果按照客户姓名升序排列: HQL : Query query = session.createQuery ("from customer c order by c.name"); QBC : Criteria criteria = session.createCriteria(customer.class); criteria.addOrder(order.asc("name")); HQL : Query query = session.createQuery ("from customer c order by c.name asc , c.age desc"); QBC : Criteria criteria = session.createCriteria(customer.class); criteria.addOrder(order.asc ("name")); criteria.addOrder(order.desc("age"));
import net.sf.hibernate.pression.Order import mypack.Order ........... Criteria criteria = session.createCritria (mypack.Order.class); criteria.addOrder(net.sf.hibernate.Order.asc("name")); ///////////HQL语句的参数绑定Query接口提供了绑定各种Hib映射类型的方法。 setBinary() setString() setBoolean() setByte() setCalendar() setCharacter() setDate() setDouble() setText() setTime() setTimestamp() setEntity()//把参数与一个持久化类的事例绑定lsit result = session.createQuery("from order o where o.customer = :customer").setEntity("customer" , customer).list ; setParameter()//绑定任意类型的参数 setProperties()//把命名参数与一个对象的属性值绑定 Query query = session.createQuery("from customer c where c.name =: name " + "and c.age =:age" ); Query.setProperties(customer);
过滤查询结果中的重复元素 使用Set集合来去除重复元素;或是使用distinct元素 Iterator iterator = session.createQuery("select distinct c.name from customer ").list().iterator(); while(iterator.hasnext()){ String name = (String) it.next() ; } ///////////使用聚集函数 count(); 记录的条数 min(); 求最小值 max(); 求最大值 avg(); 求平均值 sum(); 求和 1'查询customer中的所有记录条数 integer i = (Integer) session.createQuery("select count(*) from customer").uniqueResult(); 2'查询customer中的所有客户的平均年龄 integer i = (Integer) session.createQuery("select avg(c.age) from customer c ").uniqueResult(); 3'查询customer中的客户年龄的最大值、最小值 object [] i = (Integer) session.createQuery("select max(c.age),min(c.age) from customer c ").uniqueResult(); Integer Maxage = (Integer) i [0]; Integer Minage = (Integer) i [1]; 4'统计customer中的客户的名称数目,忽略重复的姓名 Integer cout = (Integer) session.createQuery("select count(distinct c.name) from customer c").uniqueResult(); ////////////使用分组查询 1'按姓名分组,统计customer中的相同姓名的记录数目 Iterator iterator = (Integer) session.createQuery("select c.name ,count(c) from customer c group by c.name").list.iterator(); while(iterator.hasnext()){ object[] p = (objcet[])iterator.next(); String name = p[0]; Integer cout = p[1]; } 2'按客户分组,统计每个客户的订单数量 Iterator iterator = session.crateQuery("select c.id ,c.name , count(o) from customer c join c.order o group by c.id ").list().iterator; while(iterator.hasnext()){ object[] p = (objcet[])iterator.next(); Integer id = p[0] String name = p[1]; Integer cout = p[2]; } 3'统计每个客户的订单总价 Iterator iterator = session.crateQuery("select c.id ,c.name,sum(o.price) from customer c join c.order o group by c.id").list.iterator(); while(iterator.hasnext()){ object[] p = (objcet[])iterator.next(); Integer id = p[0] String name = p[1];
|
相关推荐
HQL语句 HQL语句 HQL语句 HQL语句 HQL语句
标题:“全面解析HQL语句 非常详细直接的HQL语句的功能介绍” 描述:“非常详细直接实用的HQL语句的功能介绍看过的人保准都说好” 本篇文章将深入探讨HQL(Hibernate Query Language)的核心功能及其在数据查询...
### HQL语句详解 #### 一、HQL简介 HQL(Hibernate Query Language)是Hibernate框架中的查询语言,它提供了面向对象的方式来进行数据库查询。HQL语法接近于SQL但又有所不同,它允许开发者以面向对象的方式来表达...
hibernate-HQL语句大全
### HQL语句详解:精通Hibernate查询语言 #### 引言 HQL(Hibernate Query Language)是Hibernate框架中用于执行数据库操作的一种强大的查询语言。它提供了面向对象的语法,允许开发人员以一种接近于编程语言的方式...
HQL语句的语法结构与SQL相似,但更注重对象和类的概念。以下将详细介绍HQL语句的几个关键部分: 1. **from 子句**:这是HQL查询的起点,用于指定要查询的持久化类。例如,`from Person as p`表示从`Person`类中选择...
常见HQL语句的示例包括输出结果,以及语句的分析总结
HQL语句查询
【HQL语句经典教程】 Hibernate Query Language(HQL)是Hibernate框架提供的面向对象的查询语言,它在外观上类似于SQL,但具有显著的面向对象特性,如支持继承、多态和关联。本教程将深入讲解HQL的基本概念、用法...
本文将深入解析HQL语句的常见用法。 1. 大小写敏感性 HQL对Java类和属性的名称是大小写敏感的,但在关键字和表名方面,除了类名和属性名之外,HQL不区分大小写。因此,`SeLeCT`、`sELEct`和`SELECT`被视为相同,但`...
Hibernate框架Hql语句in中带参数的写法 Hibernate框架中,在使用HQL语句时,需要传递参数,而在HQL语句中使用in关键字时,需要特别注意参数的传递方式。在本文中,我们将讨论如何在HQL语句中使用in关键字带参数的...
HQL语句(结合实例).doc HQL语句(结合实例).doc HQL语句(结合实例).doc
汇集了hql语句中大部分常用的函数 ABS(n) 取绝对值数学函数 数学函数 JPAQL HQL ABS(column_name[数字类型对象属性])
### HQL语句使用大全 HQL(Hibernate Query Language)是一种面向对象的查询语言,它提供了灵活而强大的数据检索方式,使开发人员能够更高效地与数据库交互。本文将详细介绍HQL的基本用法及高级特性。 #### 1. ...
HQL的全称是?...HQL语句为:select jd.jdid,jd.jd from TblJd jd。怎样获得并显示查询结果? 使用'?'做占位符的参数查询,怎样设置参数的值? 命名参数查询的语法是? 怎样创建Criteria查询对象?
### HQL语句语法详解 HQL(Hibernate Query Language)是一种面向对象的查询语言,它提供了灵活而强大的机制来查询数据库中的数据,并将其映射到Java对象上。本篇文章将根据给定的信息深入探讨HQL的基本语法结构...
### HQL语句详解:Select/update/delete from where... 在探讨HQL(Hibernate Query Language)时,我们首先要了解它是一种用于Hibernate框架中的查询语言,其语法结构与标准SQL查询语言非常相似,但又针对对象关系...
HQL查询语言基础知识 HQL(Hibernate Query Language)是一种面向对象的查询语言,建立在面向对象的基础上。它提供了类SQL查询的功能,但查询目标是对象,而不是记录。HQL 拥有面向对象语言的所有特性,包括多态、...