Query:

    代表面向对象的一个Hibernate查询操作.在Hibernate中,通常使用session.createQuery()方法接收一个HQL语句,然后调用Query的

list()或uniqueResult()方法执行查询。所谓的HQL是Hibernate Query Language缩写,其语法很像SQL,但它是完全面向对象的。

在Hibernate中使用Query对象的步骤,具体:

  1.获得Hibernate的Session对象

2.编写HQL语句

3.调用session.createQuery()创建查询对象

    4.如果HQL语句包含参数,则调用Query的setXxx设置参数

5.调用Query对象的list(),或uniqueResult()方法执行查询。

①查询所有记录

@Test
public void fun3(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction();

String hql = "from Student";
Query query = session.createQuery(hql);
List<Student> list = query.list(); System.out.println(list);
}

②条件查询

public void fun4(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); String hql = "from Student Where sno = ?";
Query query = session.createQuery(hql);
query.setInteger(0, 1001);
Student stu = (Student) query.uniqueResult(); session.close();
System.out.println(stu.getGender()); }

③条件查询(命名标识符)

public void fun5(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); String hql = "from Student where sname = :aaa and sage = :bbb";
Query query = session.createQuery(hql);
query.setString("aaa","张三");
query.setInteger("bbb", 25);
List<Student> list = query.list(); session.close();
System.out.println(list.get(0).getName());
}

④分页查询

public void fun6(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); String hql = "from Student";
Query query = session.createQuery(hql);
//相当于 limit 1,3
query.setFirstResult(1);
query.setMaxResults(3);
List<Student> list = query.list();
session.close();
System.out.println(list);
}

Query中除了list()方法查询全部数据之外,还有一些其它常用方法,具体如下:

setter()方法:Query接口中提供了一系列的setter方法用于设置查询语句的参数,针对不同的数据类型,需要用到不同的setter方法。

iterator()方法:该方法用于查询语句,返回的结果是Iterator对象,在读取时只能按照顺序方式读取,它仅把使用到的数据转换成Java实体对象。

uniqueResult()方法:该方法用于返回唯一的结果,在确保只有一条记录的查询时可以使用该方法。

executeUpdate()方法:该方法是Hibernate3的新特性,它支持HQL语句的更新和删除操作。

setFirstResult()方法:该方法可以设置获取第一个记录的位置,也就是它表示从第几条记录开始查询,默认从0开始计算

setMaxResult()方法:该方法用于设置结果集的最大记录数,通常与setFirstResult()方法结合使用,用于限制结果集的范围,以实现分页功能。

Criteria是一个完全面向对象,可扩展的条件查询API,通过它完全不需要考虑数据库底层如何实现,以及SQL语句如何编写,它是Hibernate框架的核心查询对象。

Criteria查询,又称QBC查询(Query By Criteria)它是Hibernate的另一种对象检索方式。org.hibernate.criterion.Criterion是Hibernate提供的一个面向对象查询条件接口,一个单独的查询就是Criterion接口的一个实例,用于限制Criteria对象的查询,在Hibernate中Criterion对象的创建是通过Restrictions工厂类完成的,它提供了条件查询方法。通常:使用Criteria对象查询数据的主要步骤:

1)获得Hibernate的Session对象。

2)通过Session获得Criteria对象。

3)使用Restrictions的静态方法创建Criterion条件对象。(Restrictions类中提供了一系列用于设定查询条件的静态方法,这些静态方法都返回Criterion实例,每个Criterion实例代表一个查询条件。)

4)向Criteria对象中添加Criterion查询条件。Criteria的add()方法用于加入查询条件。

5)执行Criteria的list()或uniqueResult()获得结果。

 ①查询所有记录

@Test
public void fun7(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); Criteria criteria = session.createCriteria(Student.class);
List<Student> list = criteria.list(); session.close(); System.out.println(list); }

②条件查询

@Test
public void fun8(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); Criteria criteria = session.createCriteria(Student.class);
criteria.add(Restrictions.eq("name", "张三"));
List<Student> list = criteria.list(); session.close(); System.out.println(list);
}

 ③分页查询

    @Test
public void fun9(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction();
Criteria criteria = session.createCriteria(Student.class);
criteria.setFirstResult(1);
criteria.setMaxResults(3);
List<Student> list = criteria.list(); session.close();
System.out.println(list);
}

SQLQuery这个接口用于接收一个sql语句进行查询,然后调用list()或者uniqueResult()方法进行查询。但是sql语句不会直接封装到实体对象中,需要我们手动写代码才可以封装到实体中

@Test
public void fun10(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction();
SQLQuery sqlQuery = session.createSQLQuery("SELECT *FROM student");
List<Object[]> list = sqlQuery.list(); for (Object[] objects : list) {
System.out.println(Arrays.toString(objects));
}
session.close(); }

Hibernate入门(六)---------HQL语句的更多相关文章

  1. 分享知识-快乐自己:Hibernate 中的 HQL 语句的实际应用

    概要: Hibernate 支持三种查询方式: HQL查询.Criteria查询及原声 SQL (Native SQL)查询. HQL(Hibernate Query Language,Hiberna ...

  2. Hibernate 中update hql语句

    今天在MySQL中用hibernate测试update语句发现以下问题: update语句竟然不去作用: 表机构如下: create table student(sid int primary key ...

  3. Hibernate 表连接hql语句

    现有两个表 user 表 和 VIPcard 表 UserVo  user VIPcardVo 中含有 UserVo user select v from VIPCardVo v left join ...

  4. hibernate -- HQL语句总结

    1. 查询整个映射对象所有字段 //直接from查询出来的是一个映射对象,即:查询整个映射对象所有字段 String hql = "from Users"; Query query ...

  5. 【Hibernate 6】常用的hql语句以及N+1问题

    HQL:Hibernate Query Language,是Hibernate框架中的查询语言,十分接近于SQL语言!以下介绍一些常用的Hql语句: 一.测试类 Classes类: <span ...

  6. Hibernate 的HQL语句,初级

    这里讲解简单的HQL语句,因为很多比较复杂的外查询,用一般的查询很难完成 所以这里需要使用HQL @Test public void selquery(){ System.out.printf(&qu ...

  7. hibernate 之 HQL语句总结【转】

    1. 查询整个映射对象所有字段 //直接from查询出来的是一个映射对象,即:查询整个映射对象所有字段 String hql = "from Users"; Query query ...

  8. Hibernate学习之hql查询语句

    *  页面上数据的字段和数据库中字段差不多,这个时候,采用迫切连接  结构比较好,如果页面上的字段很少,要按照需求加载数据,采用带构造函数的select查询 实例讲解:转自:http://www.cn ...

  9. Hibernate框架HQL语句

    这篇随笔将会记录hql的常用的查询语句,为日后查看提供便利. 在这里通过定义了三个类,Special.Classroom.Student来做测试,Special与Classroom是一对多,Class ...

随机推荐

  1. [转]kaldi基于GMM做分类问题

    转自:http://blog.csdn.net/zjm750617105/article/details/55211992 对于每个类别的GMM有几种思路: 第一是将所有训练数据按类别分开,每类的数据 ...

  2. 【react】利用shouldComponentUpdate钩子函数优化react性能以及引入immutable库的必要性

    凡是参阅过react官方英文文档的童鞋大体上都能知道对于一个组件来说,其state的改变(调用this.setState()方法)以及从父组件接受的props发生变化时,会导致组件重渲染,正所谓&qu ...

  3. 优秀后端架构师必会知识:史上最全MySQL大表优化方案总结

    本文原作者“ manong”,原创发表于segmentfault,原文链接:segmentfault.com/a/1190000006158186 1.引言   MySQL作为开源技术的代表作之一,是 ...

  4. 微信自用高性能通用key-value组件MMKV已开源!

    1.MMKV简介 腾讯微信团队于2018年9月底宣布开源 MMKV ,这是基于 mmap 内存映射的 key-value 组件,底层序列化/反序列化使用 protobuf 实现,主打高性能和稳定性.近 ...

  5. 脑残式网络编程入门(二):我们在读写Socket时,究竟在读写什么?

    1.引言 本文接上篇<脑残式网络编程入门(一):跟着动画来学TCP三次握手和四次挥手>,继续脑残式的网络编程知识学习 ^_^. 套接字socket是大多数程序员都非常熟悉的概念,它是计算机 ...

  6. 使用本地缓存快还是使用redis缓存好?

    使用本地缓存快还是使用redis缓存好? Redis早已家喻户晓,其性能自不必多说. 但是总有些时候,我们想把性能再提升一点,想着redis是个远程服务,性能也许不够,于是想用本地缓存试试!想法是不错 ...

  7. Java-redis-雪崩优化

    缓存失效的时候如下图: 解决办法"使用互斥锁(mutex key):下面是核心伪代码 v = memcache.get(key); if (v == null) { if (memcache ...

  8. [Oracle]使用InstantClient访问Oracle数据库

    环境 操作系统: Win8.1 Enterprise Oracle开发工具: PL/SQL Developer 7.0.1.1066 (MBCS) 步骤 下载InstantClient Oracle官 ...

  9. H5拖动实现代码

    原理以后有空再说现在嘛先上代码.... ;} html,body { width: 100%; height: 100%; ; } #dragBoxContainer{ width: 150px; p ...

  10. java提高(8)---ArrayList源码

    ArrayList源码 一.定义 public class ArrayList<E> extends AbstractList<E> implements List<E& ...