第五章 HQL实用技术
5.1 使用HQL查询语句(面向对象查询语句)
5.1.1 编写HQL语句
5.1.1.1 from子句
例:from com.entity.Dept;
from Dept dept;--为持久化类Dept指定了别名dept;可省略包名
5.1.1.2 select子句
例:select dept from Dept as dept;
select dept.DeptName from Dept as dept;--选取单个属性,可选择多个
5.1.1.3 where子句
例:from Dept where DeptName=‘SALES‘;
from Dept dept where dept.DeptName=‘SALES‘;
from Dept dept where dept.location is not null;--查询地址不为空的部门
5.1.1.4 表达式
例:from Dept dept where lower(dept.DeptName)=‘sales‘;--lower()把字符串中的字母转换成小写
from Emp where year(hireDate)=1980;--year()用于获取日期字段的年份
5.1.1.5 order by子句
例:from Emp order by hireDate asc
from Emp order by hireDate,salary desc;
5.1. 执行HQL语句
5.1.2.1 声明变量并初始化
String hql = "from Emp";
构建Query对象
Query query = session.createQuery(hql);
两种执行方式
1、使用list()方法执行查询
2、使用iterator()方法执行查询
执行HQL语句步骤
1、获取session对象
2、编写HQL语句
3、创建Query对象
4、执行查询
5.2 在HQL查询语句中绑定数据
5.2.1 参数绑定形式
5.2.1.1 按参数位置绑定
例:Query query = session.createQuery("from Emp where job=? and salary>?");
query.setString(0,job);--第一个参数位置为零
query.setDouble(1,salary);
5.2.1.2 按参数名称绑定
例:Query query = session.createQuery("from Emp where job=:empJob and salary>:empSalary");
query.setString("empJob",empJob);
query.setDouble("empSalary",empSalary);
名称绑定和位置绑定:
1、使程序代码有较好的可读性
2、按名称绑定的形式有利于程序代码的维护,
5.2.2 绑定各种类型的参数
setBoolean():绑定类型为Boolean的参数
setByte():绑定类型为Byte的参数
setDouble():绑定类型为Double的参数
setDate():绑定类型为Date的参数
setString():绑定类型为String的参数
以上方法都有两种重载方式 如:
setString(int position,String val);--按位置绑定参数
setString(String name,String val);--按名称绑定参数
5.2.2.1 setParameter()方法:绑定任意类型参数
例:Query query = session.createQuery("from Emp where job=:empJob and salary>:empSalary");
query.setParameter("empJob",empJob);
query.setParameter("empSalary",empSalary);
5.2.2.2 setProperties()方法:绑定命名参数与一个对象的属性值
例: Dept depts=new Dept();
depts.setName("sales");
String hql="from Dept as dept where dept.deptName=:name";
Query query=session.createQuery(hql);
query.setProperties(depts);
List result=query.list();
5.2.3 使用uniqueResult()方法获取唯一结果
当查询结果不唯一时,不能使用query.uniqueResult()方法,否则会报错
5.3 分页和投影
5.3.1 实现数据分页查询
使用Query接口的setFirstResult(int firstResult)和setMaxResults(int maxResults)
setFirstResult(int firstResult):用与设置第一条记录的位置
setMaxResults(int maxResults):用于设置最大返回的记录条数
具体步骤:
1、使用聚合函数count()获取总记录数count;
2、计算总页数
int totalpages=(count% pageSize==0)?(count/pageSize):(count/pageSize+1);--pageSize保存每页显示的记录数
3、实现分页
query.setFirstResult((pageIndex-1)*pageSize);--pageIndex为当前页码
query.setMaxResults(pageSize);
List result=query.list();--得到分页查询的结果
5.3.2 使用投影查询
1)将每条查询结果封装成Object对象
2)将每条查询结果封装成Object数组
3)将每条查询结果通过构造函数封装成对象
5.4 使用MyEclipse反向工具
1、新建工程后,添加Hibernate支持
2、选择Hibernate3.3版本
3、创建Hibernate配置文件
4、配置数据库连接信息
5、生成持久化类和映射文件
6、进入数据库窗口
7、选择右键菜单Hibernate Reverse Engineering
8、选择主键生成器
第五章 HQL实用技术
时间: 2024-11-09 03:25:12
第五章 HQL实用技术的相关文章
《大道至简》第五章读后感
失败的过程也是过程,我觉得这句话很有深意,阅读完大道至简第五章,我又有了很深的感触. 首先是“做过程不是做工程”,过程是为了实现某种目的而经历的一些事情,过程有很多种,虽然经历了某种过程,但不一定能实现某种功能.做完过程的每一个阶段,并不等于做工程.做过程不是做工程的精义,也不是最终目的. 然后是“做过场”,做过场就好像是一种形式一样,做了没必要做的事情,就是浪费时间. 做工程的最终目的是实现客户的要求,工程只是一种实现的途径.最初做开发的前辈们,不用什么工程或者过程,也一样编出了程序,也一样解
大道至简第五章读后感
第五章 失败的过程也是过程 今天照样老师带领着我们阅读了大道至简第五章,阅读了<大道至简>的第五章,这章在前面的基础上又进了一步,有了技术和团队,加上有效的沟通,接下来就要接项目做工程. “虚有其表耳”,本章以<明皇实录>中的一句话来告诉我们一个深刻的道理:不要只求外表,只做形象工程,而是要透过表象,力求实质. 失败了不要紧,没有失败也就找不到自己的不足,也就不会发现自己的问题,更不用谈改进了.我们的前辈们就是在不断的失败中才总结出了“瀑布模型”“螺旋模型”等模型,方便了我们.但是
第五章 电子星球
第五章 电子星球 山高高兮.路长长,岁月悠悠兮.转眼空. 镇楼竹: 1. 秀竹一枝自宛然, 莫愁风雨损华年. 几番颠扑呈贞骨, 露重霜寒节更坚. 2. 纤纤凤竹长漓边, 不共山花斗野妍. 时对清流摇倩影, 溪流常伴乐怡然. 3. 坚节何愁风雨多, 晴天朗日更婆娑. 生凉不荫趋炎客, 惹得骚人为咏歌. 咏经典物理.戏现代理论物理: 在山泉水洁如冰, 溅玉飞珠迸有声. 流入大江清浊混, 滔滔何日见澄明. 一. 批驳现代理论
深入浅出Zabbix 3.0 -- 第十五章 Zabbix 协议与API
今天是六.一儿童节,祝小朋友们节日快乐!发完此文就带我家小朋友出去玩耍了. 第十五章 Zabbix 协议与API 本章将介绍和开发相关的Zabbix协议和API的内容,通过对Zabbix协议和API的深入了解,你可以利用Zabbix协议编写客户端程序并将其嵌入的产品或系统中,并将数据发送到Zabbix server,这在无法安装Zabbixagent等程序的场景(例如专用的嵌入式系统)中非常有用.你也可以利用Zabbix API开发自己的业务系统,或灵活的与现有系统整合集成. 15.1 Zabb
Linux与云计算——第二阶段 第五章:存储Storage服务器架设—分布式存储Ceph
Linux与云计算--第二阶段Linux服务器架设 第五章:存储Storage服务器架设-分布式存储Ceph 1 Ceph 配置Ceph集群 Install Distributed File System "Ceph" to Configure Storage Cluster. For example on here, Configure Cluster with 1 admin Node and 3 Storage Node like follows. | +------------
第五章搭建S3C6410开发板的测试环境
第五章本章主要介绍开发板的调试环境的搭建,以及如何将Android系统安装开发板上. 开发板是开发和学习嵌入式技术的主要硬件设备. 尽管可以在PC上开发Linux驱动,然后重新编译成ARM构架的Linux驱动模块,但最终都是要在开发板上进行测试的. 开发板从技术上说与手机类似,包含显示器.键盘.Wi-Fi.蓝牙等模块.开发板可扩展的端口多,容易开发定制的硬件. 第一节S3V6410开发板简介 S3C6410是一款低功耗.高性价比的RISC处理器,它给予ARM11内核,可以广泛应用于移动电话和通用
第五章
第五章 搭建S3C6410开发板的测试环境 ARM构架的开发板可基于X86构架的PC 在CPU指令以及二进制格式上有所不同. 安装串口调试工具 minicon 使用OK6410开发板可以使用其他方法显示Linux驱动程序输出的调试信息.此为串口调试. OK6410开发板自带一个串口.通过串口线与PC连接,linux驱动在输出调试信息的同时,通过串口线将调试信息发送到PC上. 安装.配置和测试minicom: 1.lsmod | grep usbserial 2.apt-get install m
JS复习第五章
第五章 引用类型 一.Object类型 创建object实例的方式有两种. 第一种是使用new操作符后跟object构造函数,如下所示: ver person = new Object( ) ; person.name = “Nicholas” ; person.age = 29 ; 另一种方式是使用对象字面量表示法: var person = { name : “Nicholas”, age : 29 } ; 对象字面量是向函数传递大量可选参数的首选形式. function displayIn
JavaScript高级程序设计(第3版)第五章读书笔记
第五章 引用类型 创建Object实例的方式有两种,第一种是使用new操作符后跟Object构造函数,例如: var person = new Object( ); person.name = “Nicholas”; person.age=29; 第二种是使用对象字面量表示法.如: var person = { name : “Nicholas”, age : 29 }; 在最后一个属性后面添加逗号,会在IE7及更早版本和Opera中导致错误. 两种访问对象属性的方法,一是方括号语法,例如per