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();

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/831830.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Deep Learning Part Eight--Attention 24.5.4

01.在翻译、语音识别等将一个时序数据转换为另一个时序数据的任务中&#xff0c;时序数据之间常常存在对应关系 引入了Attention的概念&#xff0c;介绍了Attention的注意力机制&#xff1a; 困难出现&#xff0c;seq2seq的问题引入&#xff1a;固定化长度问题&#xff08;过于…

【数学建模】矩阵微分方程

一、说明 我相信你们中的许多人都熟悉微分方程&#xff0c;或者至少知道它们。微分方程是数学中最重要的概念之一&#xff0c;也许最著名的微分方程是布莱克-斯科尔斯方程&#xff0c;它控制着任何股票价格。 ​​ 股票价格的布莱克-斯科尔斯模型 微分方程可以由数学中的许多…

java基于云计算的SaaS医院his信息系统源码 HIS云平台源码

目录 云HIS功能模块 1、预约挂号&#xff1a; 2、药库管理&#xff1a; 3、门诊医生站&#xff1a; 4、门诊费用&#xff1a; 5、药房管理&#xff1a; 6、治疗室&#xff08;门诊护士工作站&#xff09;&#xff1a; 7、统计分析&#xff1a; 8、财务管理&#xff1a;…

香蕉新鲜度等级识别香蕉成熟度识别分类数据集13478张4类别

数据集类型&#xff1a;图像分类用&#xff0c;不可用于目标检测无标注文件 数据集格式&#xff1a;仅仅包含jpg图片&#xff0c;每个类别文件夹下面存放着对应图片 图片数量(jpg文件个数)&#xff1a;13478 分类类别数&#xff1a;4 类别名称:["overripe","rip…

STM32G474 CMAKE VSCODE FREERTOS 导入

一. 文件准备 1. 首先下载 freertos FreeRTOS - Free RTOS Source Code Downloads, the official FreeRTOS zip file release download 2. 移动 FreeRTOS-Kenel 到 moto_control 文件夹下。 3. 将 FreeRTOSConfig.h 放到 /Core/Inc 下面 4. 由于 FreeRTOSConfig.h 中使用了…

腾讯云CentOS7使用Docker安装ElasticSearch与Kibana详细教程

文章目录 一、安装ElasticSearch二、安装Kibana 一、安装ElasticSearch 使用Docker拉取ElasticSearch镜像 这里版本选择的是7.15.2 docker pull docker.elastic.co/elasticsearch/elasticsearch:7.15.22. 查看ElasticSearch的镜像id docker images3. 创建ElasticSearch容器 …

鸿蒙开发仿咸鱼TabBar

鸿蒙开发自定义TabBar&#xff0c;实现tabBar 上中间按钮凸起效果 第一步、定义数据模型 export default class TabItemData{defaultIcon: ResourceselectedIcon: Resourcetitle: stringisMiddle: booleanconstructor(defaultIcon:Resource, selectedIcon:Resource, title:st…

【C++】文件

目录 文件文件分类文本文件的读写(ASCII文件)的读写打开文件打开文件的方式关闭文件将数据写入ASCII文件从ASCII文件读入数据 二进制存储对比ASCII和二进制存储用成员函数read和write读写二进制文件打开方式文件的读入与读出 文件 所谓文件&#xff0c;一般指存储在外部介质上…

c#学习基础1

一、复杂数据类型 1&#xff09;概述 2&#xff09;枚举 1.基本概念 枚举是一个比较特别的存在&#xff0c;它是一个被命名的整形常量的集合&#xff0c;一般用它来表示状态&#xff0c;类型等 1.1申明枚举和申明枚举变量 1.2申明枚举语法 2.在哪里申明枚举 3.枚举的使用 4…

Java 获取 Outlook 邮箱的日历事件

Java 获取 Outlook 邮箱的日历事件 1.需求描述2.实现方案3.运行结果 IDE&#xff1a;IntelliJ IDEA 2022.3.3 JDK&#xff1a;1.8.0_351 Outlook&#xff1a;Microsoft Office 2016 1.需求描述 比如现在需要获取 Outlook 邮箱中四月的全部的会议安排&#xff0c;如下图所示 …

anaconda、cuda、tensorflow、pycharm环境安装

anaconda、cuda、tensorflow、pycharm环境安装 anaconda安装 anaconda官方下载地址 本文使用的是基于python3.9的anaconda 接下来跟着步骤安装&#xff1a; 检验conda是否成功安装 安装CUDA和cuDNN 提醒&#xff0c;CUDA和cuDNN两者必须版本对应&#xff0c;否者将会出错…

Educational Codeforces Round 165 (Rated for Div. 2) (C、D)

1969C - Minimizing the Sum 题意&#xff1a; 思路&#xff1a;观察到操作数很小&#xff0c;最值问题操作数很容易想到dp&#xff0c;用表示第个元素&#xff0c;操作了次的最小值总和&#xff0c;转移的时候枚举连续操作了几次即可&#xff0c;而连续操作了几次即将全部变成…

陈随易:论技术思维和产品思维

大家好&#xff0c;我是不被定义的前端之虎陈随易。 我的个人网站是&#xff1a;https://chensuiyi.me&#xff0c;欢迎大家眼熟我。 写这篇文章呢&#xff0c;源于一次群聊。 群友有一个产品&#xff0c;其中涉及到免费用户和付费用户对 pdf 的查看权限问题&#xff0c;使用…

图像处理ASIC设计方法 笔记21 标记ASIC的顶层状态机

目录 (一)标记ASIC的工作流程1 ASIC首先从控制寄存器内读出待标记图像的基本参数2若写入了有效的启动命令,则进入下面一帧图像的标记过程。3 ASIC通过接口模块从FIFO1中读取待标记的图像4一帧图像初步标记完成后进行等价表的整理压缩5从临时标记存储器中读取临时标记送入标记…

大语言模型从Scaling Laws到MoE

1、摩尔定律和伸缩法则 摩尔定律&#xff08;Moores law&#xff09;是由英特尔&#xff08;Intel&#xff09;创始人之一戈登摩尔提出的。其内容为&#xff1a;集成电路上可容纳的晶体管数目&#xff0c;约每隔两年便会增加一倍&#xff1b;而经常被引用的“18个月”&#xf…

CSS精灵图、字体图标、HTML5新增属性、界面样式和网站 favicon 图标

精灵图 为什么要使用精灵图 一个网页中往往会应用很多小的背景图像作为修饰&#xff0c;当网页中的图像过多时&#xff0c;服务器就会频繁地接收和发送请求图片&#xff0c;造成服务器请求压力过大&#xff0c;这将大大降低页面的加载速度,因此&#xff0c;为了有效地减少服务…

扫雷实现详解【递归展开+首次必展开+标记雷+取消标记雷】

扫雷 一.扫雷设计思路二.扫雷代码逐步实现1.创建游戏菜单2.初始化棋盘3.打印棋盘4.随机布置雷5.统计周围雷的个数6.递归展开棋盘7.标记雷8.删除雷的标记9.保证第一次排雷的安全性棋盘必定展开10.排查雷11.判断输赢 三.扫雷总代码四.截图 一.扫雷设计思路 1.创建游戏菜单。  2.…

Leetcode—1056. 易混淆数【简单】Plus

2024每日刷题&#xff08;126&#xff09; Leetcode—1056. 易混淆数 &#x1f4a9;山实现代码 class Solution { public:bool confusingNumber(int n) {int arr[10] {0};int notNum 0;int arr2[12] {0};int size 0;while(n) {int x n % 10;arr[x] 1;arr2[size] x;if(…

OneFlow深度学习框原理、用法、案例和注意事项

本文将基于OneFlow深度学习框架&#xff0c;详细介绍其原理、用法、案例和注意事项。OneFlow是由中科院计算所自动化研究所推出的深度学习框架&#xff0c;专注于高效、易用和扩展性强。它提供了一种类似于深度学习库的接口&#xff0c;可以用于构建神经网络模型&#xff0c;并…

【Java基础】Maven的生命周期(clean+site+default)

1. 前言 在 Maven 出现之前&#xff0c;项目构建的生命周期就已经存在&#xff0c;开发人员每天都在对项目进行清理&#xff0c;编译&#xff0c;测试及部署&#xff0c;但由于没有统一的规范&#xff0c;不同公司甚至不同项目之间的构建的方式都不尽相同。 Maven 从大量项目…