Hibernate的QBC与HQL查询

2024-05-05 10:28
文章标签 查询 hibernate hql qbc

本文主要是介绍Hibernate的QBC与HQL查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1、Hibernate的QBC查询

2、Hibernate的HQL查询

3、NatvieSQL原生查询


1、Hibernate的QBC查询

Hibernate具有一个直观的、可扩展的条件查询API

public class Test {

   /**

    * @param args

    */

   public static void main(String[] args) {

      Session session = null;

      Transaction tx = null;

      try{

         session = HibernateUtil.getSession();

          tx = session.beginTransaction();

          //创建Criteria对象,指定需要查询的对象

          Criteria criteria = session.createCriteria(Product.class);

          //查询条件

          //通过Restrictions构造查询条件

          //Criterion c1 = Restrictions.ilike("proName", "%n%");

          //通过Property构造哦查询条件

          //Criterion c1 = Property.forName("proName").like("%n%");

          //Criterion c2 = Restrictions.between("proPrice", 50.00 , 100.00);

          //把查询条件添加到查询对象中

          //criteria.add(c1);

          //criteria.add(c2);

          //Criterion c3 = Restrictions.and(c1, c2);

          //criteria.add(c3);

          //调用list方法,返回对象的结果集合(hibernate自动封装对象)

         

          //查询分页

          //起始行数,下标从0开始

          //criteria.setFirstResult(2);

          //每页大小

          //criteria.setMaxResults(2);

         

          //排序

          //排序对象

          //Order order = Order.asc("proPrice");

          //把排序对象加入查询对象中

          //criteria.addOrder(order);

         

          //按例查询

          /*

          Product exam = new Product();

          exam.setProName("nike shoe");

          exam.setProPrice(200.0);

          //构建例子,把例子放入查询对象

          criteria.add(Example.create(exam));

          */

         

          //创建投影列表对象

          ProjectionList pl = Projections.projectionList();

          //创建投影属性,并放入投影列表对象中

         pl.add(Projections.groupProperty("proName"));

         pl.add(Projections.groupProperty("proPrice"));

          //把投影列表对象放入查询对象中

          criteria.setProjection(pl);

            

          List<Object[]> propsList = criteria.list();

          for(Object[] obj:propsList){

             String proName = (String)obj[0];

             Double proPrice = (Double)obj[1];

             System.out.println(proName+"--"+proPrice);

          }

          /*

          List<Product> stuList = criteria.list();

          for(Product s:stuList) {

             //System.out.println(s);

             System.out.println("id=="+s.getProId()+"\t name=="+s.getProName()+"\t price=="+s.getProPrice());

          }*/

         

          tx.commit();

      }catch(Exception e){

          e.printStackTrace();

          tx.rollback();

      }finally{

          HibernateUtil.closeSession();

      }

   }

}

2、Hibernate的HQL查询

        语法上与SQL类似,完全面向对象的查询,支持继承、多态、关联。

FROM子句:最简单的方式

查询所有的学生实例

Query query=session.createQuery("from Student");

query.list();

SELECT子句:选择那些对象和属性返回到结果集

查询所有的学生的姓名和年龄

Query query=session.createQuery(“select stu.name,stu.age from Student as stu");

query.list();

SELECT语句后可以跟多个任意类型的属性,返回结果保存在Object类型的数组中

//查询学生姓名和年龄

Query query=session.createQuery(“select stu.name,stu.age from Student as stu");

List<Object[]> os=query.list();

//返回的Object数组中有两个元素,第一个是学生姓名,第二个是学生年龄

SELECT语句后可以跟多个任意类型的属性,返回结果也可以保存在List

//查询学生姓名和年龄

Query query=session.createQuery(“select new List(stu.name,stu.age) from Student as stu");

List<List> lists=query.list();

SELECT语句后可以跟多个任意类型的属性,返回结果也可以是一个javabean对象

//查询学生姓名和年龄

Query query=session.createQuery(“select new Student(stu.name,stu.age) from Student as stu");

List<Student> stuList=query.list();

//注意:Student类必须有一个Student(String,int)的构造方法

SELECT子句中可以使用聚集函数、数学操作符、连接

支持的聚集函数如下: avg、sum、min、max、count

求学生的平均年龄

Query query=session.createQuery(“select avg(stu.age) from Student as stu");

List<Double> stuList=query.list();

WHERE子句:限制返回结果集的范围

查询所有性别为女性的学生实例

Query query=session.createQuery("from Student as stu where stu.sex=‘f’");

query.list();

WHERE子句中允许使用大多数SQL中可以使用的表达式

具名查询

Query namedQuery=session.getNamedQuery(String queryName);

3、NatvieSQL原生查询

        方便使用特定数据支持的SQL语句:例如Oracle的CONNECT关键字

        可移植性差:资源层如果采用了不同的数据库产品,需要修改代码

        非不得已,不推荐使用

创建Native SQL查询对象

调用Session接口上的createSQLQuery(String sql)方法。

该方法的参数为SQL的查询字符串,在SQLQuery对象上调用addEntity(Class pojoClass),设置查询返回的实体

SQLQuery query =session.createSQLQuery(“select * from student limit 2,10”)

query.addEntity(Student.class);

List<Student> stuList=query.list();

这篇关于Hibernate的QBC与HQL查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/961481

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

XML重复查询一条Sql语句的解决方法

《XML重复查询一条Sql语句的解决方法》文章分析了XML重复查询与日志失效问题,指出因DTO缺少@Data注解导致日志无法格式化、空指针风险及参数穿透,进而引发性能灾难,解决方案为在Controll... 目录一、核心问题:从SQL重复执行到日志失效二、根因剖析:DTO断裂引发的级联故障三、解决方案:修复

mysql查询使用_rowid虚拟列的示例

《mysql查询使用_rowid虚拟列的示例》MySQL中,_rowid是InnoDB虚拟列,用于无主键表的行ID查询,若存在主键或唯一列,则指向其,否则使用隐藏ID(不稳定),推荐使用ROW_NUM... 目录1. 基本查询(适用于没有主键的表)2. 检查表是否支持 _rowid3. 注意事项4. 最佳实

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现