HQL查询
创建查询对象
hql
Query hqlQuery = session.createQuery("from User");
原生语法
Query sqlQuery = session.createSQLQuery( "select {user.*} from USERS {user}").addEntity("user", User.class);
Criteria
Criteria crit = session.createCriteria(User.class);
JPA
Query ejbQuery = em.createQuery("select u from User u");
Query sqlQuery = session.createNativeQuery( "select u.USER_ID, u.FIRSTNAME, u.LASTNAME from USERS u", User.class );
分页
Query query = session.createQuery("from User u order by u.name asc"); query.setMaxResults(10);
Criteria crit = session.createCriteria(User.class); crit.addOrder( Order.asc("name") ); crit.setFirstResult(40); crit.setMaxResults(20);
Query sqlQuery = session.createSQLQuery("select {u.*} from USERS {u}") .addEntity("u", User.class); sqlQuery.setFirstResult(40); sqlQuery.setMaxResults(20);
方法链
Query query = session.createQuery("from User u order by u.name asc") .setMaxResults(10); Criteria crit = session.createCriteria(User.class) .addOrder( Order.asc("name") ) .setFirstResult(40) .setMaxResults(20);
Query query = em.createQuery("select u from User u order by u.name asc") .setFirstResult(40) .setMaxResults(20)
参数绑定
String queryString = "from Item item where item.description like :search"; Query q = session.createQuery(queryString) .setString("search", searchString);
String queryString = "from Item item" + " where item.description like :search" + " and item.date > :minDate"; Query q = session.createQuery(queryString) .setString("search", searchString) .setDate("minDate", mDate);
Query q = em.createQuery(queryString) .setParameter("search", searchString) .setParameter("minDate", mDate, TemporalType.DATE);
绑定持久化实体
session.createQuery("from Item item where item.seller = :seller").setEntity("seller", theSeller);
绑定任何hibernate类型
String queryString = "from Item item" + " where item.seller = :seller and" + " item.description like :desc"; session.createQuery(queryString) .setParameter( "seller",theSeller, Hibernate.entity(User.class) ) .setParameter( "desc", description, Hibernate.STRING );
定制的用户自定义类型
Query q = session.createQuery("from Bid where amount > :amount"); q.setParameter( "amount", givenAmount, Hibernate.custom(MonetaryAmountUserType.class) );
setProperties()绑定使得JavaBean属性的名称与查询字符串中的具体参数一致,内部调用setParameter()来猜测hibernate类型并绑定值
Item item = new Item(); item.setSeller(seller); item.setDescription(description); String queryString = "from Item item" + " where item.seller = :seller and" + " item.description like :desccription"; session.createQuery(queryString).setProperties(item);
利用定位参数
String queryString = "from Item item" + " where item.description like ?" + " and item.date > ?"; Query q = session.createQuery(queryString) .setString(0, searchString) .setDate(1, minDate);
String queryString = "from Item item" + " where item.description like ?1" + " and item.date > ?2"; Query q = em.createQuery(queryString).setParameter(1, searchString) .setParameter(2, minDate, TemporalType.DATE);
设置查询提示
可以在session中通过setFlushMode()来禁止持久化上下文清除
只对特定的查询之前禁用清除
Query q = session.createQuery(queryString).setFlushMode(FlushMode.COMMIT); Criteria criteria = session.createCriteria(Item.class).setFlushMode(FlushMode.COMMIT); Query q = em.createQuery(queryString).setFlushMode(FlushModeType.COMMIT);
高速缓存模式
Query q = session.createQuery("from Item") .setCacheMode(CacheMode.IGNORE); Criteria criteria = session.createCriteria(Item.class) .setCacheMode(CacheMode.IGNORE); Query q = em.createQuery(queryString) .setHint("org.hibernate.cacheMode", org.hibernate.CacheMode.IGNORE);
CacheMode.IGNORE告诉hibernate不要为这个查询返回的任何实体而与二级缓存交互
禁用脏查询
Query q = session.createQuery("from Item").setReadOnly(true); Criteria criteria = session.createCriteria(Item.class).setReadOnly(true); Query q = em.createQuery("select i from Item i") .setHint("org.hibernate.readOnly", true);
设置超时,控制一个查询运行多久
Query q = session.createQuery("from Item").setTimeout(60); // 1 minute Criteria criteria = session.createCriteria(Item.class).setTimeout(60); Query q = em.createQuery("select i from Item i").setHint("org.hibernate.timeout", 60);
抓取大小
Query q = session.createQuery("from Item").setFetchSize(50); Criteria criteria = session.createCriteria(Item.class).setFetchSize(50); Query q = em.createQuery("select i from Item i") .setHint("org.hibernate.fetchSize", 50);
定制注释
Query q = session.createQuery("from Item").setComment("My Comment..."); Criteria criteria = session.createCriteria(Item.class).setComment("My Comment..."); Query q = em.createQuery("select i from Item i") .setHint("org.hibernate.comment", "My Comment...");
强制悲观锁
Query q = session.createQuery("from Item item").setLockMode("item", LockMode.UPGRADE); Criteria criteria = session.createCriteria(Item.class).setLockMode(LockMode.UPGRADE);
执行查询
列表
List result = myQuery.list(); List result = myCriteria.list(); List result = myJPAQuery.getResultList();
获得单个实例
Bid maxBid = (Bid) session.createQuery("from Bid b order by b.amount desc").setMaxResults(1).uniqueResult(); Bid bid = (Bid) session.createCriteria(Bid.class).add( Restrictions.eq("id", id) ).uniqueResult(); Bid maxBid = (Bid) em.createQuery("select b from Bid b order by b.amount desc").setMaxResults(1) .getSingleResult();
循环访问结果
Query categoryByName = session.createQuery("from Category c where c.name like :name"); categoryByName.setString("name", categoryNamePattern); List categories = categoryByName.list();
Query categoryByName = session.createQuery("from Category c where c.name like :name"); categoryByName.setString("name", categoryNamePattern); Iterator categories = categoryByName.iterate();
游标滚动
ScrollableResults itemCursor = session.createQuery("from Item").scroll(); itemCursor.first(); itemCursor.last(); itemCursor.get(); itemCursor.next(); itemCursor.scroll(3); itemCursor.getRowNumber(); itemCursor.setRowNumber(5); itemCursor.previous(); itemCursor.scroll(-3); itemCursor.close();
ScrollableResults itemCursor = session.createCriteria(Item.class) .scroll(ScrollMode.FORWARD_ONLY); ... // Scroll only forward itemCursor.close()
使用具名查询
<query name="findItemsByDescription"><![CDATA[ from Item item where item.description like :desc ]]></query>
session.getNamedQuery("findItemsByDescription").setString("desc", description);
em.createNamedQuery("findItemsByDescription").setParameter("desc", description);
<query name="findItemsByDescription" cache-mode="ignore" comment="My Comment..." fetch-size="50" read-only="true" timeout="60"><![CDATA[ from Item item where item.description like :desc ]]></query>
<sql-query name="findItemsByDescription"> <return alias="item" class="Item"/> <![CDATA[ select {item.*} from item where description like :desc ]]> </sql-query>
@NamedQueries({ @NamedQuery( name = "findItemsByDescription", query = "select i from Item i where i.description like :desc" ), ... }) @Entity @Table(name = "ITEM") public class Item { ... }
限制
from User u where u.email = 'foo@hibernate.org'
from Item i where i.isActive = true
from Bid bid where bid.amount between 1 and 10 from Bid bid where bid.amount > 100 from User u where u.email in ('foo@bar', 'bar@foo')
from User u where u.email is null from Item i where i.successfulBid is not null
from User u where u.firstname like 'G%'
from User u where u.firstname not like '%Foo B%' from User u where u.firstname not like '\%Foo%' escape='\'
from Bid bid where ( bid.amount / 0.71 ) - 100.0 > 0.0 from User user where user.firstname like 'G%' and user.lastname like 'K%' from User u where ( u.firstname like 'G%' and u.lastname like 'K%' ) or u.email in ('foo@hibernate.org', 'bar@hibernate.org' )
包含集合的表达式
from Item i where i.bids is not empty from Item i, Category c where i.id = '123' and i member of c.items
调用函数
from User u where lower(u.email) = 'foo@hibernate.org' from User user where concat(user.firstname, user.lastname) like 'G% K%' from Item i where size(i.bids) > 3
排序
from User u order by u.username from User u order by u.username desc from User u order by u.lastname asc, u.firstname asc
投影
Query q = session.createQuery("from Item i, Bid b"); // Query q = em.createQuery("select i, b from Item i, Bid b"); Iterator pairs = q.list().iterator(); // Iterator pairs = q.getResultList().iterator(); while ( pairs.hasNext() ) { Object[] pair = (Object[]) pairs.next(); Item item = (Item) pair[0]; Bid bid = (Bid) pair[1]; }
上面例子在标准JPA QL中是无效的
select i.id, i.description, i.initialPrice from Item i where i.endDate > current_date()
distinct
select distinct item.description from Item item
调用特定函数
select item.startDate, current_date() from Item item select item.startDate, item.endDate, upper(item.name) from Item item
联接
隐式关联查询
from User u where u.homeAddress.city = 'Bangkok' select distinct u.homeAddress.city from User u from Bid bid where bid.item.description like '%Foo%'
from Bid bid where bid.item.category.name like 'Laptop%' and bid.item.successfulBid.amount > 100
在from中表达的联接
from Item i join i.bids b where i.description like '%Foo%' and b.amount > 100
select i.DESCRIPTION, i.INITIAL_PRICE, ... b.BID_ID, b.AMOUNT, b.ITEM_ID, b.CREATED_ON from ITEM i inner join BID b on i.ITEM_ID = b.ITEM_ID where i.DESCRIPTION like '%Foo%' and b.AMOUNT > 100
Query q = session.createQuery("from Item i join i.bids b"); Iterator pairs = q.list().iterator(); while ( pairs.hasNext() ) { Object[] pair = (Object[]) pairs.next(); Item item = (Item) pair[0]; Bid bid = (Bid) pair[1]; }
select i from Item i join i.bids b where i.description like '%Foo%' and b.amount > 100
Query q = session.createQuery("select i from Item i join i.bids b"); Iterator items = q.list().iterator(); while ( items.hasNext() ) { Item item = (Item) items.next(); }
联接的动态抓取策略
from Item i left join fetch i.bids where i.description like '%Foo%'
from Bid bid left join fetch bid.item left join fetch bid.bidder where bid.amount > 100
报表查询
Long count = (Long) session.createQuery("select count(i) from Item i") .uniqueResult();
select count(i.successfulBid) from Item i select sum(i.successfulBid.amount) from Item i
select min(bid.amount), max(bid.amount) from Bid bid where bid.item.id = 1
select count(distinct i.description) from Item i
select bid.item.id, avg(bid.amount) from Bid bid group by bid.item.id
select bid.item.id, count(bid), avg(bid.amount) from Bid bid where bid.item.successfulBid is null group by bid.item.id
select bidItem.id, count(bid), avg(bid.amount) from Bid bid join bid.item bidItem where bidItem.successfulBid is null group by bidItem.id
select user.lastname, count(user) from User user group by user.lastname having user.lastname like 'A%'
select item.id, count(bid), avg(bid.amount) from Item item join item.bids bid where item.successfulBid is null group by item.id having count(bid) > 10
子查询
from User u where 10 < ( select count(i) from u.items i where i.successfulBid is not null )
from Bid bid where bid.amount + 1 >= ( select max(b.amount) from Bid b )
量词
from Item i where 100 > all ( select b.amount from i.bids b ) from Item i where 100 <= any ( select b.amount from i.bids b ) from Item i where 100 = some ( select b.amount from i.bids b ) from Item i where 100 in ( select b.amount from i.bids b )
List result = session.createQuery("from Category c" + " where :givenItem in elements(c.items)") .setEntity("givenItem", item) .list()
相关推荐
### HQL查询及语法详解 #### 一、HQL简介 HQL,全称为Hibernate Query Language,是Hibernate框架提供的一种面向对象的查询语言。它基于SQL标准,但更加强调对象模型,支持Java中的对象关系映射(ORM),能够处理...
### HQL查询详解 HQL(Hibernate Query Language)是一种面向对象的查询语言,它提供了与SQL类似的功能,但更贴近于面向对象编程的思维方式。HQL允许开发人员以一种更自然的方式查询数据库,同时保持了Java对象模型...
SSH笔记-HQL查询(基于位置参数查询、基于命名参数查询、分页查询、命名查询、投影查询报表查询、内/迫切内/左外/迫切左外连接查询)、QBC(QBC检索查询、统计查询、排序查询、HQL操作数据库)、本地SQL查询
这里的关键点在于使用`createQuery`方法创建了一个HQL查询对象,并通过`setString`方法设置参数值,最后通过`list`方法执行查询并获取结果列表。 #### 三、分页查询 分页查询在处理大量数据时非常有用,可以有效地...
### Spring框架中HQL查询方法详解 在Spring框架与Hibernate技术结合使用时,HQL(Hibernate Query Language)作为对象查询语言被广泛应用于数据查询操作之中。本文将详细解析Spring框架中常用的HQL查询方法及其应用...
HQL 查询语言基础知识 HQL(Hibernate Query Language)是一种面向对象的查询语言,用于在 Hibernate 框架中查询数据库。HQL 查询语言基础知识是 Hibernate 中的基础组件之一,对于开发人员来说,掌握 HQL 查询语言...
JPA--HQL查询(手动写原生查询sql,复杂查询必备) JPA(Java Persistence API)是一种JavaEE标准,用于持久化数据,HQL(Hibernate Query Language)是 Hibernate 框架提供的一种查询语言,它允许开发者使用面向...
标题"HibernateUtil分装完整版HQL查询"暗示了这是一个关于使用HibernateUtil工具类来封装和执行HQL(Hibernate Query Language)查询的教程或代码示例。描述中的重复信息进一步强调了这个主题,意味着我们将探讨如何...
**HQL查询语言基础** HQL(Hibernate Query Language)是Hibernate框架中用于操作对象关系映射(ORM)的查询语言,它与SQL类似,但专为面向对象编程设计。HQL允许开发者以类和对象的方式编写查询,而不是直接处理...
HQL查询的使用极大地提高了开发效率,因为它将数据操作与具体的数据库结构分离。 **1. HQL的基本语法** HQL查询语句结构通常包括以下几个部分:`SELECT`, `FROM`, `WHERE`, `GROUP BY`, `HAVING`, `ORDER BY`。...
【标题】:深入理解Hibernate的查询机制:HQL查询 【描述】:在ORM框架Hibernate中,数据查询和检索是一个核心功能,它提供了多种查询方式,包括标准化对象查询(Criteria Query)、Hibernate查询语言(HQL)和原生...
HQL查询 帮助文档
《Hibernate HQL查询语法详解》 Hibernate,作为Java领域中广泛应用的对象关系映射(ORM)框架,极大地简化了数据库操作。其内置的HQL(Hibernate Query Language)是一种面向对象的查询语言,它允许开发者以类和...
本文将深入探讨“常用易懂,易会”的HQL查询,帮助你快速上手并熟练掌握这一技能。 1. **HQL基础概念** HQL是Hibernate提供的面向对象的查询语言,与SQL类似,但更加面向对象,减少了数据库方言的差异,提高了代码...
HQL查询
在HQL查询语言中,`FROM`子句用于指定查询数据来源的实体或表。例如: ```hql FROM Person as p ``` 这里的`Person`表示的是一个持久化类,即ORM映射中的实体类。`as p`则定义了一个别名`p`,方便后续在查询语句中...
在实际项目中,结合Hibernate的注解方式和HQL查询,开发者可以高效地处理数据库操作,降低了SQL编写的工作量,提高了代码的可读性和可维护性。同时,Hibernate还提供了Criteria API和Querydsl等其他查询方式,提供了...
hql查询多个实体类,类之间有外键关系,但是没有外键关联
### Hibernate HQL 查询详解 #### 一、HQL 概述 Hibernate 提供了一种非常强大的查询语言——HQL(Hibernate Query Language),它在语法上与 SQL 类似但功能更为强大,因为它支持面向对象的特性,例如继承、多态性...
### HQL查询语句详解 #### 一、HQL简介 Hibernate Query Language(HQL)是一种面向对象的查询语言,其语法与SQL相似但并非完全相同。HQL的设计旨在更好地支持面向对象编程特性,比如继承、多态以及关联等概念。...