【Hibernate框架开发之八】Hibernate 查询语言Query Language(HQL)

简介:

 生成一条HQL查询语句  Query,  使用Session的createQuery("hql语句")生成Query

HQL语句:

1. “from className”

class是类名;Hibernate会自动到数据库中找对应生成的表;

 

2.“from className cn where cn.name > 'xx'”

cn 是className的别名,  'xx'表示条件

 

3. "from ClassName cn order by cn.name desc"

按照className的名字倒序排列

 

4. "select distinct cn from ClassName cn order by cn.name desc"

互相之间不会重复的对象(主键不同)的按照倒序排列

 

5. "from ClassName cn where cn.id > :min and cn.id< :max"

然后设置其Parameter(min和max)   :

query.setParameter("min", 2);           query.setParameter("max", 8);

query.setInteger("min", 2);                  query.setInteger("max", 8);

(两段实现相同功能,使用setParameter则自动转换类型,下面属于手动转换类型);

 

6."select cn.id,cn.name from ClassName cn order by cn.name desc"

取出特定的两个字段 id 和 name

 

7. "from ClassName cn where cn.group.id =1 "

找到在ClassName生成的表中中的group对象的id为1的那个ClassName对象

 

8.  "select cn.id,g.name from ClassName cn Join cn.group g"

映射ClassName的cn.id对应ClassName中group对象里的name属性;join 建立导航关系

 

9.  "select count(*) from ClassName cn"

使用聚合函数, 注意count(*)返回Long类型;

 

10. "select max(cn.id), min(cn.id), avg(cn.id), sum(cn.id) from ClassName cn"

聚合函数

 

11. "from ClassName cn where cn.id between 3 and 7"

两者之间

 

12. "from ClassName cn where cn.id in (3,4,5)"

是否在其中

 

13. "from ClassName cn where cn.name is not null"

不为null

 

14.   "from ClassName cn where cn.set is empty"

判断集合属性是否为空

is not empty 测试某一个属性是否为空

 

15.  "from ClassName cn where cn.name like '%4'"

"from ClassName cn where cn.name like '_4'"

%: 表示0个或者多个

_:表示一个

 

16."select lower(cn.name),lower(cn.name),upper(cn.name),trim(cn.name),concat(cn.name),length(cn.name) from ClassName cn"

一些常用函数

 

17. "select abs(cn.id),sqrt(cn.id) from ClassName cn"

一些函数

 

18. "select current_date,current_time,current_timestamp,t.id from ClassName t"

时间日期

 

19. "from ClassName cn where cn.createDate < :date"

日期的比较

 

20. "select cn.name,count(*) from ClassName cn group by cn.name"

.分组查询

 

21. "select cn.name,count(*) from ClassName cn group by cn.name having count(*) >= 2"

.

22. "from ClassName cn where cn.id < (select avg(cn.id) from ClassName cn)"

哪个id值<平均值

 

23. "from ClassName cn where cn.id < ALL(select cn.id from ClassName cn where mod(cn.id ,2) = 0)"

id 小于ALL(2,4,6,8)所有值   ps..小于最小值 =   select min

 

24. "update ClassName cn set cn.name = upper(cn.name)"

更新

 

Query函数:

1. Query 中 有个 list()函数,直接获取其数据返回一个list对象;

2. Query 中uniqueResult()函数,得到唯一返回的值;

3. executeUpdate() 更新

 









本文转自 xiaominghimi 51CTO博客,原文链接:http://blog.51cto.com/xiaominghimi/969787,如需转载请自行联系原作者
目录
相关文章
|
19天前
|
缓存 Java 数据库连接
Hibernate:Java持久层框架的高效应用
通过上述步骤,可以在Java项目中高效应用Hibernate框架,实现对关系数据库的透明持久化管理。Hibernate提供的强大功能和灵活配置,使得开发者能够专注于业务逻辑的实现,而不必过多关注底层数据库操作。
12 1
|
2月前
|
Java 数据库连接 API
解锁高效开发秘籍:深入探究 Hibernate 如何优雅处理一对多与多对多关系,让数据映射再无烦恼!
【9月更文挑战第3天】Hibernate 是 Java 领域中最流行的 ORM 框架之一,广泛用于处理实体对象与数据库表之间的映射。尤其在处理复杂关系如一对多和多对多时,Hibernate 提供了丰富的 API 和配置选项。本文通过具体代码示例,展示如何使用 `@OneToMany`、`@JoinColumn`、`@ManyToMany` 和 `@JoinTable` 等注解优雅地实现这些关系,帮助开发者保持代码简洁的同时确保数据一致性。
51 4
|
2月前
|
SQL Java 数据库连接
Hibernate 批量操作来袭!掌握最佳实践,轻松应对数据洪流,开启高效开发新时代
【9月更文挑战第3天】在软件开发中,高效数据操作至关重要。作为流行的Java持久化框架,Hibernate提供了强大的数据库操作功能。本文探讨了Hibernate批量操作,包括批量插入、更新和删除的最佳实践,通过使用原生SQL和`Session`的`createNativeQuery()`方法,结合`addBatch()`及`executeBatch()`方法实现高效批量操作。合理设置批量大小、事务管理和性能测试是优化的关键。在实际开发中,应根据业务需求和性能要求选择合适的方法,以提升程序性能和可维护性。
189 3
|
3月前
|
SQL 数据库 Java
HQL vs SQL:谁将统治数据库查询的未来?揭秘Hibernate的神秘力量!
【8月更文挑战第31天】Hibernate查询语言(HQL)是一种面向对象的查询语言,它模仿了SQL的语法,但操作对象为持久化类及其属性,而非数据库表和列。HQL具有类型安全、易于维护等优点,支持面向对象的高级特性,内置大量函数,可灵活处理查询结果。下面通过示例对比HQL与SQL,展示HQL在实际应用中的优势。例如,HQL查询“从员工表中筛选年龄大于30岁的员工”只需简单地表示为 `FROM Employee e WHERE e.age &gt; 30`,而在SQL中则需明确指定表名和列名。此外,HQL在处理关联查询时也更为直观易懂。然而,对于某些复杂的数据库操作,SQL仍有其独特优势。
58 0
|
3月前
|
API Java 数据库连接
从平凡到卓越:Hibernate Criteria API 让你的数据库查询瞬间高大上,彻底告别复杂SQL!
【8月更文挑战第31天】构建复杂查询是数据库应用开发中的常见需求。Hibernate 的 Criteria API 以其强大和灵活的特点,允许开发者以面向对象的方式构建查询逻辑,同时具备 SQL 的表达力。本文将介绍 Criteria API 的基本用法并通过示例展示其实际应用。此 API 通过 API 构建查询条件而非直接编写查询语句,提高了代码的可读性和安全性。无论是简单的条件过滤还是复杂的分页和连接查询,Criteria API 均能胜任,有助于提升开发效率和应用的健壮性。
121 0
|
3月前
|
数据库 开发者 Java
颠覆传统开发:Hibernate与Spring Boot的集成,让你的开发效率飞跃式提升!
【8月更文挑战第31天】在 Java 开发中,Spring Boot 和 Hibernate 已成为许多开发者的首选技术栈。Spring Boot 简化了配置和部署过程,而 Hibernate 则是一个强大的 ORM 框架,用于管理数据库交互。将两者结合使用,可以极大提升开发效率并构建高性能的现代 Java 应用。本文将通过代码示例展示如何在 Spring Boot 项目中集成 Hibernate,并实现基本的数据库操作,包括添加依赖、配置数据源、创建实体类和仓库接口,以及在服务层和控制器中处理 HTTP 请求。这种组合不仅简化了配置,还提供了一套强大的工具来快速开发现代 Java 应用程序。
198 0
|
3月前
|
数据库 Java 数据库连接
Struts 2 与 Hibernate 的完美邂逅:如何无缝集成两大框架,轻松玩转高效 CRUD 操作?
【8月更文挑战第31天】本文通过具体示例介绍了如何在 Struts 2 中整合 Hibernate,实现基本的 CRUD 操作。首先创建 Maven 项目并添加相关依赖,接着配置 Hibernate 并定义实体类及其映射文件。然后创建 DAO 接口及实现类处理数据库操作,再通过 Struts 2 的 Action 类处理用户请求。最后配置 `struts.xml` 文件并创建 JSP 页面展示用户列表及编辑表单。此示例展示了如何配置和使用这两个框架,使代码更加模块化和可维护。
85 0
|
3月前
|
SQL Java 数据库连接
|
6月前
|
SQL 缓存 Java
框架分析(9)-Hibernate
框架分析(9)-Hibernate
|
3月前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
47 1