Hibernate 框架 -HQL 语法
2019-08-16 12:11:51来源:博客园 阅读 ()
Hibernate 框架 -HQL 语法
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(); }
以上查询都是单表查询,没有涉及多表查询,多表查询等我们熟悉好这几个查询,才继续学习多表查询。多表查询比单表查询复杂一点点。
原文链接:https://www.cnblogs.com/HHHY/p/11323528.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:JAVA可视化闹钟源码
下一篇:Spring AOP源码
- Java--反射(框架设计的灵魂)案例 2020-06-11
- Java--反射(框架设计的灵魂) 2020-06-11
- 与JAVA集合相遇 2020-06-11
- Java框架之Hibernate实战篇 2020-06-09
- 拼多多三面惨败,问题在于java中间件、数据库与spring框架. 2020-06-04
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash