Hibernate查询的六种方式
Hibernate查询的六种方式 分别是HQL查询,对象化查询Criteria方法,动态查询DetachedCriteria,例子查询,sql查询,命名查询。
如果单纯的使用hibernate查询数据库只需要懂其中的一项就可以完成想要实现的一般功能,但是想多学知识就看一下这六种方法,他们提供了更多选择。当然每一种方法都有其适用的情况与前提。
1、HQL查询
HQL是hibernate自己的一套查询语言,于SQL语法不同,具有跨数据库的优点。示例代码:
- static void query(String name){
- Session s=null;
- try{
- s=HibernateUtil.getSession();
- //from后面是对象,不是表名
- String hql="from Admin as admin where admin.aname=:name";//使用命名参数,推荐使用,易读。
- Query query=s.createQuery(hql);
- query.setString("name", name);
- List<Admin> list=query.list();
- for(Admin admin:list){
- System.out.println(admin.getAname());
- }
- }finally{
- if(s!=null)
- s.close();
- }
- }

适用情况:常用方法,比较传统,类似jdbc。缺点:新的查询语言,适用面有限,仅适用于Hibernate框架。
2、对象化查询Criteria方法:
- static void cri(String name,String password){
- Session s=null;
- try{
- s=HibernateUtil.getSession();
- Criteria c=s.createCriteria(Admin.class);
- c.add(Restrictions.eq("aname",name));//eq是等于,gt是大于,lt是小于,or是或
- c.add(Restrictions.eq("apassword", password));
- List<Admin> list=c.list();
- for(Admin admin:list){
- System.out.println(admin.getAname());
- }
- }finally{
- if(s!=null)
- s.close();
- }
- }

适用情况:面向对象操作,革新了以前的数据库操作方式,易读。缺点:适用面较HQL有限。
3、动态分离查询DetachedCriteria
- static List dc(DetachedCriteria dc) {
- Session s = HibernateUtil.getSession();
- Criteria c = dc.getExecutableCriteria(s);
- List rs = c.list();
- s.close();
- return rs;
- }

- DetachedCriteria dc = DetachedCriteria.forClass(User.class);
- int id = 1;
- if (id != 0)
- dc.add(Restrictions.eq("id", id));
- Date age = new Date();
- if (age != null)
- dc.add(Restrictions.le("birthday", age));
- List users = dc(dc);
- System.out.println("离线查询返回结果:" + users);

适用情况:面向对象操作,分离业务与底层,不需要字段属性摄入到Dao实现层。 缺点:适用面较HQL有限。
4、例子查询
- static List example(User user) {
- Session s = HibernateUtil.getSession();
- List<User> users = s.createCriteria(User.class).add(
- Example.create(user)).list();
- // List<User>
- // users2=s.createCriteria(User.class).add((Example.create(user)).ignoreCase())
- // .createCriteria("child").add((Example.create(user))).list();
- return users;
- }

适用情况:面向对象操作。 缺点:适用面较HQL有限,不推荐。
5、sql查询
- static List sql() {
- Session s = HibernateUtil.getSession();
- Query q = s.createSQLQuery("select * from user").addEntity(User.class);
- List<User> rs = q.list();
- s.close();
- return rs;
- }

适用情况:不熟悉HQL的朋友,又不打算转数据库平台的朋友,万能方法 缺点:破坏跨平台,不易维护,不面向对象。
6、命名查询
- static List namedQuery(int id) {
- Session s = HibernateUtil.getSession();
- Query q = s.getNamedQuery("getUserById");
- q.setInteger("id", id);
- return q.list();
- }

- <?xml version="1.0" encoding="utf-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- <hibernate-mapping>
- <class name="com.sy.vo.User" table="user" catalog="news">
- </class>
- <!-- 命名查询:定义查询条件 -->
- <query name="getUserById">
- <![CDATA[from User where id=:id]]>
- </query>
- <!-- 命名查询中使用sql,不推荐使用,影响跨数据库
- <sql-query name="getUserById2">
- <![CDATA[select * from User where ]]>
- </sql-query> -->
- </hibernate-mapping>
Hibernate查询的六种方式的更多相关文章
- 六种方式实现hibernate查询
最近在学习Hibernate的基本内容,刚好在项目中有用到,基本上都是用到哪就学哪. 今天看看六种方式实现hibernate查询......... 分别是HQL查询,对象化查询Criteria方法,动 ...
- 六种方式实现hibernate查询,及IDE推荐
这些天过的好乱,也许是因为考完试了,心里有些松懈吧.也许是最近发生的事对我有些触动吧.感觉自己都已经不懂自己了.面对一些人的教导,我很感激.因为很多话都对我有非常大的帮助和启发,也让我除了做技术, ...
- hibernate查询方式
hibernate查询方式:1.本地SQL查询 2.HQL查询 3.QBC查询 HQL查询:是面向对象的查询语言,是使用最广的一种查询方法 QBC查询:Query by Criteria是一套接口来实 ...
- (十)Hibernate 查询方式
所有项目导入对应的hibernate的jar包.mysql的jar包和添加每次都需要用到的HibernateUtil.java 第一节:Hibernate 查询方式简介 1,导航对象图查询方式: 2 ...
- 二。Hibernate 查询 HQL、SQL方式
hibernate的查询1.HQL方式:所有查询都是根据java对象名来完成,对象名替换表名2.SQL方式:保留原来的sql查询风格3.可以通过设置第一条和最大条数来实现各种数据库的分页查询4.通过B ...
- Hibernate查询方式(补)
-----------------siwuxie095 Hibernate 查询方式 1.对象导航查询 根据已经加载的对 ...
- Redis查询&JDBC查询&Hibernate查询方式的效率比较...
比较三种查询方式查询效率对比...我是用的JavaWeb的方式通过通过JSP页面查询的填写查询的参数...给予反馈.... 整个demo的下载地址:http://files.cnblogs.com/f ...
- Hibernate学习10——Hibernate 查询方式
本章主要是以查询Student的例子: Student.java: package com.cy.model; public class Student { private int id; priva ...
- Hibernate 查询方式、JPA查询方式
hibernate 查询方式: OID 查询 对象导航查询 HQL 方式查询 QBC方式查询 原生SQL方式查询 JPA 查询方式: OID 查询 对象导航查询 JPQL 方式查询 CriteriaB ...
随机推荐
- Ubuntu16.04系统中不同版本Python之间的转换
Ubuntu系统自带的版本是2.7.12 安装好python3.6之后,改变一下Python的优先级(需要root权限). 在使用下面这个命令查看电脑里面有几个Python版本 update-alte ...
- ThinkPHP微信扫码支付接口
最近折腾微信扫码支付,看了微信官方文档,找了很多网页,发现和文档/demo不匹配,现在自己算是弄出来了(文件名称有所更改),贴出来分享一下 一.将有用的官方lib文件和使用的相关文件放置到vendor ...
- iOS通过切片仿断点机制上传文件
项目开发中,有时候我们需要将本地的文件上传到服务器,简单的几张图片还好,但是针对iPhone里面的视频文件进行上传,为了用户体验,我们有必要实现断点上传.其实也不是真的断点,这里我们只是模仿断点机制. ...
- Cloudera Manager 安装集群遇到的坑
Cloudera Manager 安装集群遇到的坑 多次安装集群,但每次都不能顺利,都会遇到很多很多的坑,今天就过去踩过的坑简单的总结一下,希望已经踩了的和正在踩的童鞋能够借鉴一下,希望对你们能有所帮 ...
- linux几个重要的组合键
我们在用Windows系统时,有没有感觉快键键让我们工作更有效率,在Linux系统中仍有很好用的快捷键,这些快捷键可以辅助我们进行指令的编写与程序的中断呢,下面介绍几个经常用到的快捷键. 一.Tab- ...
- kubernetes常用基础命令
创建资源对象 创建名为nginx-deploy的控制器资源对象 [root@master ~]# kubectl run nginx-deploy --image=nginx:1.12 --repli ...
- spark 例子groupByKey分组计算
spark 例子groupByKey分组计算 例子描述: [分组.计算] 主要为两部分,将同类的数据分组归纳到一起,并将分组后的数据进行简单数学计算. 难点在于怎么去理解groupBy和groupBy ...
- 接口与协议学习笔记-Ethernet UDP通信协议(一)
总线(BUS,即公共汽车,数据的公共传输路线)分类的方式有很多,如被分为外部和内部总线.系统总线和非系统总线等等,下面是几种最常用的分类方法.另外,总线的传输核心思想是多路复用:时分多路复用-TDMA ...
- Matlab调用C语言函数
Matlab调用C语言函数 如果我有一个用C语言写的函数,实现了一个功能,如一个简单的函数:double add(double x, double y) { return x + y ;}现在我想要在 ...
- 20155213 《JAVA程序设计》实验二(JAVA面向对象程序设计)实验报告
20155213 <JAVA程序设计>实验二(JAVA面向对象程序设计)实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S ...