HQL查询——HQL查询的基本用法

1.HQL语法类似于SQL语法,但是需要注意的是,HQL是一种完全面向对象的查询语言。SQL语言操作的对象是数据表、列等数据库对象,而HQL语言的操作对象是类、实例、属性等。

2.由于HQL语言是面向对象的查询语言,所以他具有面向对象的特征,即支持继承和多态。

3.HQL查询依赖于Hibernate提供的Query类,每个Query类实例对应一个查询对象。

4.使用HQL查询的步骤如下:

(1)获取Hibernate Session对象;

(2)编写HQL语句;

(3)如果以HQL语句作为参数,调用Session的createQuery()方法创建查询对象;

(4)如果HQL语句包含参数,则调用Query的setXxx()方法为参数赋值;

(5)调用Query对象的list()方法或者uniqueResult()方法返回查询结果列表(持久化实体集)。

5.执行HQL查询的例子:

 import java.text.SimpleDateFormat;
 import java.util.Arrays;
 import java.util.Date;
 import java.util.List;

 import org.hibernate.Session;
 import org.hibernate.Transaction;

 /**
  * @author admin
  *    使用HQL查询的例子
  */
 public class HqlQuery {
     public static void main(String[] args)throws Exception {
         HqlQuery mgr = new HqlQuery();
         //调用第一个查询方法
         mgr.findPersons();
         //调用第二个查询方法
         mgr.findPersonsByHappenDate();
         //调用第三个查询方法
         mgr.findPersonProperty();
     }
     //第一个查询方法
     private void findPersons(){
         //获得Hibernate Session对象
         Session session = HibernateUtil.currentSession();
         //开始事务
         Transaction tx = session.beginTransaction();
         //使用HQL语句创建Query对象
         List pl = session.createQuery("select distinct p from Person p join p.myEvents where title = :eventTitl")
                 //执行setString方法为HQL语句中的参数赋值
                 .setString("eventTile", "普通事情")
                 //使用Query实例的list()方法获取查询的全部实例
                 .list();
         //遍历查询的全部结果
         for(Object ele : pl){
             Person p = (Person)ele;
             System.out.println(p.getName());
         }
         //提交事务
         tx.commit();
         //关闭Session
         HibernateUtil.closeSession();
     }
     //第二个查询方法
     private void findPersonsByHappenDate()throws Exception{
         //获取Hibernate Session对象
         Session session = HibernateUtil.currentSession();
         //开始事务
         Transaction tx = session.beginTransaction();
         //解析出Date对象
         SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
         Date start = new Date("2017-01-03");
         //通过Session对象的createQuery()方法创建Query对象
         List pl = session.createQuery("select distinct p from Person p inner join p.myEvents evebt "
                 + "where event.happenDate"
                 + "between:firstDate and :endDate").
                 //设置参数
                 setDate("firstDate", start).
                 setDate("endDate", new Date()).
                 //返回结果
                 list();
         //遍历结果集
         for(Object ele:pl){
             Person p = (Person)ele;
             System.out.println(p.getName());
         }
         //提交事务
         tx.commit();
         //关闭Session
         HibernateUtil.closeSession();
     }
     //第三个查询方法:属性的查询
     private void findPersonProperty(){
         //获得Session对象
         Session session = HibernateUtil.currentSession();
         //开始事务
         Transaction tx = session.beginTransaction();
         //使用HQL创建Query对象
         List pl = session.createQuery("select distinct p.id,p.name,p.age"
                 + "from Person p join p.myEvents")
                 //Query调用list()方法查询得到的全部属性
                 .list();
         //遍历查询的全部结果
         for(Object ele:pl){
             Object[] objs = (Object[])ele;
             System.out.println(Arrays.toString(objs));
         }
         //提交事务
         tx.commit();
         //关闭Session对象
         HibernateUtil.closeSession();
     }
 }

6.HQL语句中可以使用占位符作为参数。HQL中的占位符既可以使用英文问号+索引的形式(?N);也可以使用有名字的占位符,使用有名字的占位符时,应该在占位符名字前增加英文冒号(:)。

7.成功编写了HQL语句以后就可以使用Session对象的createQuery(hql)方法创建一个Query,Query对象使用setXxx()方法为HQL语句的参数赋值。Query的所有setXxx()方法都有两个版本,分别用于根据参数索引赋值和根据参数名字赋值。

8.Query对象可以连续为多次的参数赋值,因为Query对象的setXxx()方法返回的依然是一个Query对象本身,在最后使用Query对象的list()方法来获取查询到的全部结果。

9.注意:HQL语句本身是不区分大小写的。即HQL语句的关键字、函数都是不区分大小写的。但是HQL语句中的所使用的包名、类名、实例名、属性名都是区分大小写的。

HQL查询——HQL查询的基本用法的更多相关文章

  1. HQL常用的查询语句

    摘录自某人,比较有用,比较全. // HQL: Hibernate Query Language. // 特点: // >> 1,与SQL相似,SQL中的语法基本上都可以直接使用. // ...

  2. Hibernate的几种查询方式-HQL,QBC,QBE,离线查询,复合查询,分页查询

    HQL查询方式 这一种我最常用,也是最喜欢用的,因为它写起来灵活直观,而且与所熟悉的SQL的语法差不太多.条件查询.分页查询.连接查询.嵌套查询,写起来与SQL语法基本一致,唯一不同的就是把表名换成了 ...

  3. 《Java从入门到放弃》入门篇:hibernate查询——HQL

    不知不觉又到了hibernate的最后一篇了,只感觉时光飞逝~,岁月如梭~! 转眼之间,我们就···························,好吧,想装个X,结果装不下去了,还是直接开始吧· ...

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

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

  5. HQL和SQL查询

     转自http://blog.csdn.net/aaa1117a8w5s6d/article/details/7757097 HQL和SQL的区别 标签: sqlhibernatejavasessio ...

  6. HQL多表查询

    ------------------siwuxie095 HQL 多表查询 以客户和联系人为例(一对多) 1.内连接 (1)hql 语句写法 from Customer c inner join c. ...

  7. Hibernate HQL多表查询

    1.内连接和迫切内连接 (1)内连接 HQL语句:from 实体类名 实体类别名 inner join 实体类别名.表示另一个表数据的集合名称 (2)迫切内连接 HQL语句:from 实体类名 实体类 ...

  8. Hibernate 笔记 HQL查询 条件查询,聚集函数,子查询,导航查询

    在hibernate中进行多表查询,每个表中各取几个字段,也就是说查询出来的结果集并没有一个实体类与之对应,如何解决这个问题? 解决方案一,按照Object[]数据取出数据,然后自己组bean 解决方 ...

  9. Hibernate的批量查询——HQL

    HQL(Hibernate Query Language)查询: 1.查询所有学生信息: public static void testSel() { Session session = Hibern ...

随机推荐

  1. EntityFramework优缺点

    高层视图: 改变在现有系统使用EntityFramework的优势是什么? • All -in-1框架的类映射表,需要编写映射代码, 并且是很难维护的. • 可维护性,易于理解的代码,无需创造大的数据 ...

  2. linux io stack

  3. Python中的浅拷贝 深拷贝

    浅拷贝只拷贝父对象,子对象的地址空间不改变,包括下面三种: 1. copy 从下面的例子可以看出对象c从a拷贝,当对象a增加一个列表元素之后,c对象没有改变, 而当对象a中的子列表改变时,对象c的子列 ...

  4. axis2打包方式发布

    参照http://gao-xianglong.iteye.com/blog/1744557这篇文章,注意的是打包services.xml的时候要将它的上级目录meta-inf一起打包,放到axis2\ ...

  5. STM32 assert_param

    在STM32的固件库和提供的例程中,到处都可以见到assert_param()的使用.如果打开任何一个例程中的stm32f10x_conf.h文件,就可以看到实际上assert_param是一个宏定义 ...

  6. 不同数据库中同一张表的SQL循环修改语句

    select sample_value,Sample_GUID,row_number() over(order by sample_value )as rownumber into  #AATemp  ...

  7. 精华 对express中next函数的一些理解

        关于next主要从三点来进行说明: next的作用是什么? 我们应该在何时使用next? next的内部实现机制是什么? Next的作用 我们在定义express中间件函数的时候都会将第三个参 ...

  8. Android 音量调节

    对于Android的音量调节,可以分为按键调节音量和设置中调节音量.我们首先说一说设置中的音量调节. 一.音量的分类: 1.AudioManager.STREAM_VOICE_CALL 2.Audio ...

  9. 浅析JS中的模块规范(CommonJS,AMD,CMD)////////////////////////zzzzzz

    浅析JS中的模块规范(CommonJS,AMD,CMD)   如果你听过js模块化这个东西,那么你就应该听过或CommonJS或AMD甚至是CMD这些规范咯,我也听过,但之前也真的是听听而已.     ...

  10. 安装freetds小记

    FreeTDS的软件获取:在官网上进行下载:http://www.freetds.org/ 执行以下命令: ./configure --with-tdsver=7.1 --enable-msdblib ...