第五章 HQL实用技术

第五章   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、选择主键生成器

时间: 2024-08-30 05:41:09

第五章 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