HQL ( Hibernate Query Language ) 查询语言是面向对象的查询语言,也是在 Hibernate 中最常见的。其语法和 SQL 语法有一些相似,功能十分强大,几乎支持除特殊 SQL 扩展外的所有查询功能。此种查询方式为 Hibernate 官方推荐的标准查询方式。

  以下我直接使用上一篇文章配置好的持久化类和工具类来写。

  这篇文章我多以代码的形式来说明 HQL 语法的使用。

1、基本语法查询

// 基本语法

    @Test
public void fun1() {
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
// -----------------------------------------------------
String hql = "from Customer";
Query query = session.createQuery(hql);
List<Customer> list = query.list();
System.out.println(list); // -----------------------------------------------------
tx.commit();
session.close();
}

2、条件查询

// 条件查询

    @Test
public void fun2() {
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
// -----------------------------------------------------
String hql = "from Customer where cust_id = ?";
String hql1 = "from Customer where cust_id = :id";//另外一种查询语句写法
Query query = session.createQuery(hql1);
// query.setParameter(0, 2l);
query.setParameter("id", 2l);
List<Customer> list = query.list();
System.out.println(list); // -----------------------------------------------------
tx.commit();
session.close();
}

3、排序查询

// 排序

    @Test
public void fun3() {
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
// -----------------------------------------------------
String hql = "from Customer order by cust_id asc";// asc:升序 desc:降序
Query query = session.createQuery(hql);
List<Customer> list = query.list();
System.out.println(list); // -----------------------------------------------------
tx.commit();
session.close();
}

4、分页查询

// 分页查询

    @Test
public void fun4() {
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
// -----------------------------------------------------
String hql = "from Customer";
Query query = session.createQuery(hql);
// 开始的下标=(当前页数-1)*每页条数
query.setFirstResult(0);
query.setMaxResults(3);
List<Customer> list = query.list();
System.out.println(list); // -----------------------------------------------------
tx.commit();
session.close();
}

5、聚合函数查询

// 统计查询
// count
// sum
// avg
// max
// min @Test
public void fun5() {
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
// -----------------------------------------------------
String hql1 = "select count(*) from Customer"; // 统计条数
String hql2 = "select sum(cust_id) from Customer"; // 求和
String hql3 = "select avg(cust_id) from Customer"; // 求平均值
String hql4 = "select max(cust_id) from Customer"; // 求最大值
String hql5 = "select min(cust_id) from Customer"; // 求最小值
Query query = session.createQuery(hql3);
Number result = (Number) query.uniqueResult();
System.out.println(result); // -----------------------------------------------------
tx.commit();
session.close();
}

6、投影查询

// 投影查询

    @Test
public void fun6() {
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
// ----------------------------------------------------- String hql1 = "select new Customer(cust_id,cust_name) from Customer";
Query query = session.createQuery(hql1);
List<Customer> list = query.list();
System.out.println(list); // -----------------------------------------------------
tx.commit();
session.close();
}

  

  以上查询都是单表查询,没有涉及多表查询,多表查询等我们熟悉好这几个查询,才继续学习多表查询。多表查询比单表查询复杂一点点。

最新文章

  1. 【WCF】终结点的监听地址
  2. python下如何安装biopython
  3. IOS学习之路七(使用 Operation 异步运行任务)
  4. HDU2948Geometry Darts(简单计算几何)
  5. CentOS系统cobbler完全部署及案例测试
  6. js中substring和substr的用法 (转)
  7. jQuery插件autoComplete使用
  8. ResourceString的用法
  9. 5.7.13mysql 无法登陆
  10. Viso设置背景
  11. css中的em 简单教程 -- 转
  12. cmd命令中运行pytest命令导入模块报错解决方法
  13. Docker安装准备
  14. oracle 之 统计函数、子查询、操作符
  15. python中常用的模块一
  16. 设计模式——适配器模式(type-c转3.5mm耳机口)
  17. Struts2 (下)
  18. MIPS 汇编指令学习
  19. Java中的集合框架-Map
  20. java 实现对指定目录的文件进行下载

热门文章

  1. &lt;算法基础&gt;&lt;排序&gt;三种高级排序——快速排序,堆排序,归并排序
  2. 3分钟了解ServiceStage 应用智能化运维【华为云分享】
  3. 搞IT产品,请谨记Mobile First
  4. J.U.C剖析与解读2(AQS的由来)
  5. luogu P1759 通天之潜水
  6. idea建立项目关联到git仓库操作步骤
  7. 高质量iOS博客推荐
  8. 压缩感知重构算法之OMP算法python实现
  9. [TimLinux] JavaScript 阻止父节点接收子节点事件的方法
  10. 前端flex布局学习笔记