Hibernate查询的六种方式 分别是HQL查询,对象化查询Criteria方法,动态查询DetachedCriteria,例子查询,sql查询,命名查询

如果单纯的使用hibernate查询数据库只需要懂其中的一项就可以完成想要实现的一般功能,但是想多学知识就看一下这六种方法,他们提供了更多选择。当然每一种方法都有其适用的情况与前提。

1、HQL查询

HQL是hibernate自己的一套查询语言,于SQL语法不同,具有跨数据库的优点。示例代码:

  1. static void query(String name){
  2. Session s=null;
  3. try{
  4. s=HibernateUtil.getSession();
  5. //from后面是对象,不是表名
  6. String hql="from Admin as admin where admin.aname=:name";//使用命名参数,推荐使用,易读。
  7. Query query=s.createQuery(hql);
  8. query.setString("name", name);
  9. List<Admin> list=query.list();
  10. for(Admin admin:list){
  11. System.out.println(admin.getAname());
  12. }
  13. }finally{
  14. if(s!=null)
  15. s.close();
  16. }
  17. }

适用情况:常用方法,比较传统,类似jdbc。缺点:新的查询语言,适用面有限,仅适用于Hibernate框架。

2、对象化查询Criteria方法

  1. static void cri(String name,String password){
  2. Session s=null;
  3. try{
  4. s=HibernateUtil.getSession();
  5. Criteria c=s.createCriteria(Admin.class);
  6. c.add(Restrictions.eq("aname",name));//eq是等于,gt是大于,lt是小于,or是或
  7. c.add(Restrictions.eq("apassword", password));
  8. List<Admin> list=c.list();
  9. for(Admin admin:list){
  10. System.out.println(admin.getAname());
  11. }
  12. }finally{
  13. if(s!=null)
  14. s.close();
  15. }
  16. }

适用情况:面向对象操作,革新了以前的数据库操作方式,易读。缺点:适用面较HQL有限。

3、动态分离查询DetachedCriteria

  1. static List dc(DetachedCriteria dc) {
  2. Session s = HibernateUtil.getSession();
  3. Criteria c = dc.getExecutableCriteria(s);
  4. List rs = c.list();
  5. s.close();
  6. return rs;
  7. }
  1. DetachedCriteria dc = DetachedCriteria.forClass(User.class);
  2. int id = 1;
  3. if (id != 0)
  4. dc.add(Restrictions.eq("id", id));
  5. Date age = new Date();
  6. if (age != null)
  7. dc.add(Restrictions.le("birthday", age));
  8. List users = dc(dc);
  9. System.out.println("离线查询返回结果:" + users);

适用情况:面向对象操作,分离业务与底层,不需要字段属性摄入到Dao实现层。  缺点:适用面较HQL有限。

 

4、例子查询

  1. static List example(User user) {
  2. Session s = HibernateUtil.getSession();
  3. List<User> users = s.createCriteria(User.class).add(
  4. Example.create(user)).list();
  5. // List<User>
  6. // users2=s.createCriteria(User.class).add((Example.create(user)).ignoreCase())
  7. // .createCriteria("child").add((Example.create(user))).list();
  8. return users;
  9. }

适用情况:面向对象操作。   缺点:适用面较HQL有限,不推荐。

5、sql查询

  1. static List sql() {
  2. Session s = HibernateUtil.getSession();
  3. Query q = s.createSQLQuery("select * from user").addEntity(User.class);
  4. List<User> rs = q.list();
  5. s.close();
  6. return rs;
  7. }

适用情况:不熟悉HQL的朋友,又不打算转数据库平台的朋友,万能方法   缺点:破坏跨平台,不易维护,不面向对象。

 

6、命名查询

  1. static List namedQuery(int id) {
  2. Session s = HibernateUtil.getSession();
  3. Query q = s.getNamedQuery("getUserById");
  4. q.setInteger("id", id);
  5. return q.list();
  6. }
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
  4. <hibernate-mapping>
  5. <class name="com.sy.vo.User" table="user" catalog="news">
  6. </class>
  7. <!-- 命名查询:定义查询条件 -->
  8. <query name="getUserById">
  9. <![CDATA[from User where id=:id]]>
  10. </query>
  11. <!-- 命名查询中使用sql,不推荐使用,影响跨数据库
  12. <sql-query name="getUserById2">
  13. <![CDATA[select * from User where ]]>
  14. </sql-query> -->
  15. </hibernate-mapping>

Hibernate查询的六种方式的更多相关文章

  1. 六种方式实现hibernate查询

    最近在学习Hibernate的基本内容,刚好在项目中有用到,基本上都是用到哪就学哪. 今天看看六种方式实现hibernate查询......... 分别是HQL查询,对象化查询Criteria方法,动 ...

  2. 六种方式实现hibernate查询,及IDE推荐

      这些天过的好乱,也许是因为考完试了,心里有些松懈吧.也许是最近发生的事对我有些触动吧.感觉自己都已经不懂自己了.面对一些人的教导,我很感激.因为很多话都对我有非常大的帮助和启发,也让我除了做技术, ...

  3. hibernate查询方式

    hibernate查询方式:1.本地SQL查询 2.HQL查询 3.QBC查询 HQL查询:是面向对象的查询语言,是使用最广的一种查询方法 QBC查询:Query by Criteria是一套接口来实 ...

  4. (十)Hibernate 查询方式

     所有项目导入对应的hibernate的jar包.mysql的jar包和添加每次都需要用到的HibernateUtil.java 第一节:Hibernate 查询方式简介 1,导航对象图查询方式: 2 ...

  5. 二。Hibernate 查询 HQL、SQL方式

    hibernate的查询1.HQL方式:所有查询都是根据java对象名来完成,对象名替换表名2.SQL方式:保留原来的sql查询风格3.可以通过设置第一条和最大条数来实现各种数据库的分页查询4.通过B ...

  6. Hibernate查询方式(补)

    -----------------siwuxie095                             Hibernate 查询方式         1.对象导航查询     根据已经加载的对 ...

  7. Redis查询&JDBC查询&Hibernate查询方式的效率比较...

    比较三种查询方式查询效率对比...我是用的JavaWeb的方式通过通过JSP页面查询的填写查询的参数...给予反馈.... 整个demo的下载地址:http://files.cnblogs.com/f ...

  8. Hibernate学习10——Hibernate 查询方式

    本章主要是以查询Student的例子: Student.java: package com.cy.model; public class Student { private int id; priva ...

  9. Hibernate 查询方式、JPA查询方式

    hibernate 查询方式: OID 查询 对象导航查询 HQL 方式查询 QBC方式查询 原生SQL方式查询 JPA 查询方式: OID 查询 对象导航查询 JPQL 方式查询 CriteriaB ...

随机推荐

  1. SQL-还原数据库,数据库提示正在还原中的处理办法

    还原数据库时,提示还原成功,可是数据库列表中该数据库显示正在还原中: 执行此命令即可: RESTORE DATABASE EnterPriseBuilding WITH RECOVERY 1. 至少有 ...

  2. staticmethod classmethod

    1. 静态方法 @staticmethod 只是名义上归类管,实际上静态方法里访问不了类或者实例中的任何属性 2. 类方法 @classmethod 只能访问类变量,不能访问实例变量 3.属性方法 @ ...

  3. grep基础用法详解

    适合初学linux的人学得比较凌乱的人看这个也能理理思路学得更系统,节约你的学习时间,提高效率,但是思维导图的作用是帮人理清思路不会迷失在细节中,细节补充学习请参考https://www.cnblog ...

  4. 一位老手关于HTML5的见解

    HTML5新特性总结  HTML5属于上一代HTML的新迭代语言,设计HTML5最主要的目的是为了在移动设备上支持多媒体!!!例如: video 标签和 audio 及 canvas 标记   HTM ...

  5. redis具体使用

    key 命名规则:不可包含空格和\n 创建方式: set  key value values Strings (Binary-safe strings) Lists Sets Sorted sets ...

  6. centos7 远程连接mongodb时,27017端口连接不上的解决办法

    一.问题描述:centos 7 上安装mongogdb,然后通过另外一台电脑用pymongo连接mongodb时,报错:连接拒绝 解决过程: 1.修改mongo.conf文件 命令:sudo  vi  ...

  7. Flume(3)-安装部署

    一. 下载 Flume官网地址 http://flume.apache.org/ 文档查看地址 http://flume.apache.org/FlumeUserGuide.html 下载地址 htt ...

  8. 第一篇 C/C++基本语言类型

    总概: { C:面向过程,以过程为中心,以算法为驱动 } { C++:面向对象,以过对象中心,以消息为驱动 个人理解:一切皆对象的思想 } 一 前言总概 1.常量变量 初始化对象与赋值是两个概念 直接 ...

  9. md5.digest()与md5.hexdigest()之间的区别及转换

    举给例子 md5 = hashlib.md5('adsf') md5.digest() //返回: '\x05\xc1*(s48l\x94\x13\x1a\xb8\xaa\x00\xd0\x8a' # ...

  10. 20155319 实验二 Java面向对象程序设计

    20155319 实验二 Java面向对象程序设计 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 了解设计模式 (一) ...