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. #leetcode刷题之路23-合并K个排序链表

    合并 k 个排序链表,返回合并后的排序链表.请分析和描述算法的复杂度. 示例:输入:[ 1->4->5, 1->3->4, 2->6]输出: 1->1->2- ...

  2. No space left on device 解决 Cydia 安装应用错误

    在 Cydia 上搜索应用进行安装,提示错误:failed to write (No space left on device),从字面上的意思看是磁盘空间不够,导致写入错误,但是到 “关于” 里看到 ...

  3. 大数据学习系列之—HBASE

    hadoop生态系统 zookeeper负责协调 hbase必须依赖zookeeper flume 日志工具 sqoop 负责 hdfs dbms 数据转换 数据到关系型数据库转换 大数据学习群119 ...

  4. 树莓派安装SimpleCV

    开源计算机视觉框架.python2 安装 (http://simplecv.readthedocs.io/en/latest/HOWTO-Install%20on%20RaspberryPi.html ...

  5. C语言编程练习 GPS数据处理

    题目内容: NMEA-0183协议是为了在不同的GPS(全球定位系统)导航设备中建立统一的BTCM(海事无线电技术委员会)标准,由美国国家海洋电子协会(NMEA-The National Marine ...

  6. 20155308 2016-2017-2 《Java程序设计》实验3

    20155308 2016-2017-2 <Java程序设计>实验3 实验内容 XP基础 XP核心实践 相关工具 实验步骤 (一)敏捷开发与XP 敏捷开发是一种以人为核心.迭代.循序渐进的 ...

  7. 20155320 2016-2017-2《Java程序设计》第1周学习总结

    20155320 2016-2017-2<Java程序设计>第1周学习总结 教材学习内容总结 本周学习内容 浏览课本,并就每一章提出一个问题. 认真学习第一.第二章的内容. 1至18章每章 ...

  8. bootstrap 内边框样式

    css设置: .table>tbody>tr>td, .table>tbody>tr>th, .table>tfoot>tr>td, .table ...

  9. Oracle下建立dblink时的权限问题

    如果用普通用户,如果没授权,是无法建立dblink的: [oracle@oracle000 ~]$ sqlplus gao/gao lines) SQL Production :: Copyright ...

  10. 【LG3243】[HNOI2015]菜肴制作

    题面 洛谷 题解 首先我们有个非常显然的思路, 就是直接拓扑排序,用小根堆代替队列再按顺序输出,但是很显然是错的, 因为这只保证了字典序最小,而无法保证答案最优,\(<2,4>,<3 ...