Hibernate主要查询方式
1.hql查询
1.1 无参数的hql查询
1.2 带参的hql查询(分为问号占位和字符占位两种)
Ps: 绑定各种类型的参数时用setParameter()绑定参数,如封装方法后用不定参数时循环绑定参数;也可以使用setProperties()动态绑定,但是不如criteria查询
2.特殊hql查询方法
2.1 uniqueResult()查询唯一结果
需要注意的是,当查询结果不唯一时,会报NonUniqueResultException的错,谨慎使用该方法
2.2 分页查询
2.3 投影查询
返回值是Object集合,下标与语句中属性值顺序相对应
2.4 将查询结果通过构造函数封装成对象
String hql = “select new Emp(empName,salary) from Emp”;
Emp类中必须要有该构造函数,或者新建一个javabean
3.原生SQL查询
使用createSQLQuery()方法,方法参数为原生SQL语句,并提供addEntity()方法将查询结果集中的关系数据映射为对象,否则用Object数据的集合来接收
4.命名查询
4.1 hql查询语句的命名查询
在映射文件中使用<query>元素定义HQL语句,与<class>元素并列
使用的时候调用getNamedQuery()方法,参数为<query>元素中的name属性值,并可以链式设置参数
4.2 sql查询语句的命名查询
Sql语句包裹在<sql-query>元素中,增加一个return元素,alias属性为操作的表取别名,class属性则表示映射的实体类
调用时使用相同的getNamedQuery()方法
5.Criteria查询
5.1使用步骤
<a>使用Session接口的createCriteria()方法创建Criteria对象
<b>使用Restrictions类提供的静态方法设置查询条件,这些静态方法返回Criterion对象,一个Criterion对象代表一个查询条件。Criteria接口的add()方法用来添加查询条件,也可以设置分页
<c>使用Criteria接口的list()方法执行查询语句
5.2 Restrictions类的各种静态方法
(1) eq(String propertyName,Object value) 等于
(2) ne(String propertyName,Object value) 不等于
(3) gt(String propertyName,Object value) 大于
(4) ge(String propertyName,Object value) 大于等于
(5) lt(String propertyName,Object value) 小于
(6) le(String propertyName,Object value) 小于等于
(7) isNull(String propertyName) 等于空值
(8) isNotNull(String propertyName) 不等于空值
5.3查询范围关键字
(1)in(String propertyName,Collection values)或
In(String propertyName,Object[] values) 等于列表中的某一个值
(2)not in 不等于列表中的任意一个值
(3)Between(String propertyName, Object low,Object high)
大于等于low值并且小于等于high
(4)not Between(String propertyName, Object low,Object high)
小于low值或者大于high
(5)like/ilike(String propertyName,Object value)或
like/ilike(String propertyName,Object value,MatchMode matchMode)
根据字符串和匹配模式进行匹配
匹配模式:START 以字符串开头
END 以字符串结束
ANYWHERE 字符串出现在任何位置
EXACT 精确匹配
5.4 连接查询(只支持内连接和迫切左外连接)
Hibernate主要查询方式的更多相关文章
- Hibernate的查询方式总结
Hibernate的查询方式大体有三种,分别是HQL QBC和SQL三种.在网上查阅一一些资料,做了一个简单的总结. 1. SQL sql 是面向数据库表查询,from 后面跟的是表名,where 后 ...
- 4、Hibernate的查询方式
一.Hibernate的查询方式:OID查询 1.OID检索:Hibernate根据对象的OID(主键)进行检索 1-1.使用get方法 Customer customer = session.get ...
- Hibernate的查询方式
Hibernate的查询的方式 OID检索 get或load方法进行的查询 对象导航检索 linkman.getCustomer(); HQL检索 用于接收hql语句进行查询,面向对象查询方式. 通过 ...
- Hibernate各种查询方式及查询策略(转)
转自:https://www.cnblogs.com/xujingyang/p/6734203.html 在了解Hibernate的基本知识后,重点让我们看下相关查询方式和查询优化策略吧! 话不多说, ...
- hibernate(七) hibernate中查询方式详解
序言 之前对hibernate中的查询总是搞混淆,不明白里面具体有哪些东西.就是因为缺少总结.在看这篇文章之前,你应该知道的是数据库的一些查询操作,多表查询等,如果不明白,可以先去看一下 MySQL数 ...
- Hibernate学习(七)———— hibernate中查询方式详解
序言 之前对hibernate中的查询总是搞混淆,不明白里面具体有哪些东西.就是因为缺少总结.在看这篇文章之前,你应该知道的是数据库的一些查询操作,多表查询等 --WH 一.hibernate中的5种 ...
- Hibernate的查询方式汇总
分别是HQL查询,对象化查询Criteria方法,动态查询DetachedCriteria,例子查询,sql查询,命名查询. 如果单纯的使用hibernate查询数据库只需要懂其中的一项就可以完成想要 ...
- hibernate的查询方式的介绍(一)
1.对象导航查询 2.OID查询 3.hql(hibernate query language)查询 4.QBC查询 5.本地sql查询 在这里先介绍其中两种 1.hibernate的对象导航查询 ( ...
- hibernate select查询方式总结
https://www.cnblogs.com/xingege/p/4270990.html
随机推荐
- 大文件LOG持续输出
作了两个版本,一是websocket输出,一是直接显示指定行数. class WebSocketHandler(tornado.websocket.WebSocketHandler): file_co ...
- python常用模块1
一. 什么是模块: 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编写的代码 ...
- 小程序 之使用HMACSHA1算法加密报文
首先说说我们前端常用的加密技术, 我们常用的加密技术有:如MD5加密,base64加密 今天要说的是HMACSHA1加密技术 先介绍下什么是SHA1算法, 安全哈希算法(Secure Hash Alg ...
- Codeforces Gym101502 J-取数博弈
还有J题,J题自己并不是,套的板子,大家写的都一样,因为大家都是套板子过的,贴一下代码,等学会了写一篇博客... J.Boxes Game 代码: 1 //J. Boxes Game-取数博弈-不会, ...
- Java泛型总结---基本用法,类型限定,通配符,类型擦除
一.基本概念和用法 在Java语言处于还没有出现泛型的版本时,只能通过Object是所有类型的父类和类型强制转换两个特点的配合来实现类型泛化.例如在哈希表的存取中,JDK1.5之前使用HashMap的 ...
- 作为一个新人,怎样学习嵌入式Linux?
作为一个新人,怎样学习嵌入式Linux? 在学习嵌入式Linux之前,肯定要有C语言基础.汇编基础有没有无所谓(就那么几条汇编指令,用到了一看就会).尝试着写一些C语言竞赛的题目.它们是纯 ...
- spring事务详细理解
数据并发的问题 一个数据库可能拥有多个访问客户端,这些客户端都可以并发方式访问数据库.数据库中的相同数据可能同时被多个事务访问,如果没有采取必要的隔离措施,就会导致各种并发问题,破坏数据的完整性.这些 ...
- [反汇编练习] 160个CrackMe之032
[反汇编练习] 160个CrackMe之032. 本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注 ...
- AngularJS的form状态变色
代码下载:https://files.cnblogs.com/files/xiandedanteng/angularjsChangeFormClass.rar 代码: <!DOCTYPE HTM ...
- source insight的查找功能
source insight是一款非常好的c语言的程序编辑器.方便对project管理,方便程序的阅读和编辑. 查找功能使用十分频繁.选项较多,与其他软件的查找功能也类似,以下对英文版的查找功能,做简 ...