Query对象

我们使用Query对象不需要编写SQL语句,但是得写HQL语句。

HQL:Hibernate Query Language;Hibernate提供的查询语言,和SQL语句很相似。

HQL和SQL的区别:

  使用SQL操作的是表和表字段;  

  使用HQL操作的是实体类和实体类的属性;

查询所有记录的HQL:from 实体类名称

Query对象的使用:

步骤一:创建Query对象;

步骤二:调用Query对象里面的方法得到结果;

代码演示:

@Test

//使用Query对象

public void testQuery(){

SessionFactory sessionFactory = null;

Session session = null;

Transaction transaction = null;

try {

sessionFactory = HibernateUtil.getSessionFactory();

session = sessionFactory.openSession();

//开启事务

transaction = session.beginTransaction();

//1 创建Query对象

//编写HQL语句

Query query = session.createQuery("from User");

//2 调用Query对象里面的方法得到结果

List<User> userList = query.list();

for (User user : userList) {

System.out.println(user);

}

//提交事务

transaction.commit();

} catch (Exception e) {

// TODO: handle exception

e.printStackTrace();

transaction.rollback();

}finally{

session.close();

sessionFactory.close();

}

}

Hibernate:

select

user0_.ID as ID1_0_,

user0_.USERNAME as USERNAME2_0_,

user0_.PASSWORD as PASSWORD3_0_,

user0_.ADDRESS as ADDRESS4_0_

from

USER user0_

User [id=1, username=yyyyyy, password=null, address=null]

User [id=3, username=uc, password=up, address=tw]

User [id=4, username=qqqqq, password=111111, address=shanxi]

User [id=7, username=nihao111, password=nihaopwd111, address=U.S.A111]

Criteria对象

说明:使用这个对象也可以实现查询操作,但是使用这个对象的时候,不需要编写HQL语句,直接调用方法就可以了。

使用过程和Query很相似:

过程如下:

  • 创建Criteria对象;
  • 调用对象里面的方法得到结果;

代码演示:

//1 创建Criteria对象

Criteria criteria = session.createCriteria(User.class);

//2 调用Query对象里面的方法得到结果

List<User> userList = criteria.list();

for (User user : userList) {

System.out.println(user);

}

Hibernate:

select

this_.ID as ID1_0_0_,

this_.USERNAME as USERNAME2_0_0_,

this_.PASSWORD as PASSWORD3_0_0_,

this_.ADDRESS as ADDRESS4_0_0_

from

USER this_

User [id=1, username=yyyyyy, password=null, address=null]

User [id=3, username=uc, password=up, address=tw]

User [id=4, username=qqqqq, password=111111, address=shanxi]

User [id=7, username=nihao111, password=nihaopwd111, address=U.S.A111]

SQLQuery对象

使用Hibernate的时候,也可以调用底层SQL语句来实现。

实现过程:

1、创建SQLQuery对象;

2、调用对象的方法实现;

代码演示:

SQLQuery sqlQuery = session.createSQLQuery("select * from user");

//2 调用Query对象里面的方法得到结果

//返回的list集合,默认是数组结构

List<Object[]> userList = sqlQuery.list();

for (Object[] userObject : userList) {

System.out.println(Arrays.toString(userObject));

}

Hibernate:

select

*

from

user

[1, yyyyyy, null, null]

[3, uc, up, tw]

[4, qqqqq, 111111, shanxi]

[7, nihao111, nihaopwd111, U.S.A111]

解决问题:返回list中的每部分是对象形式

//1 创建SQLQuery对象

SQLQuery sqlQuery = session.createSQLQuery("select * from user");

sqlQuery.addEntity(User.class);

//2 调用Query对象里面的方法得到结果

//返回的list集合,默认是数组结构

List<User> userList = sqlQuery.list();

for (User userObject : userList) {

System.out.println(userObject);

}

Hibernate:

select

*

from

user

User [id=1, username=yyyyyy, password=null, address=null]

User [id=3, username=uc, password=up, address=tw]

User [id=4, username=qqqqq, password=111111, address=shanxi]

User [id=7, username=nihao111, password=nihaopwd111, address=U.S.A111]

Hibernate API的使用(Query、Criteria、SQLQuery对象)的更多相关文章

  1. 五 Hibernate的其他API,Query&Criteria&SQLQuery

    Query Criteria SQLQuery Query接口:用于接收HQL,用于查询多个对象 HQL:Hibernate Query Language  Query条件查询: Query分页查询: ...

  2. [原创]java WEB学习笔记77:Hibernate学习之路---Hibernate 版本 helloword 与 解析,.环境搭建,hibernate.cfg.xml文件及参数说明,持久化类,对象-关系映射文件.hbm.xml,Hibernate API (Configuration 类,SessionFactory 接口,Session 接口,Transaction(事务))

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  3. Hibernate框架 初识 ORM概念 搭建Hibernate环境 Hibernate Api

    ORM概念 在学习 Hibernate 之前,我们先来了解ORM   对象关系映射 O, Object  对象 R,Realtion 关系  (关系型数据库: MySQL, Oracle…) M,Ma ...

  4. hibernate学习之Hibernate API

    1. Hibernate Api分类 1)提供访问数据库的操作(如保存,更新,删除,查询)的接口.这些接口包括:Session, Transaction,,Query接口. 2)由于配置Hiberna ...

  5. 【转】让EntityManager的Query返回Map对象

    在JPA 2.0中我们可以使用entityManager.createNativeQuery()来执行原生的SQL语句.但当我们查询结果没有对应实体类时,需使用entityManager.create ...

  6. Hibernate API申明事务边界

    在Hibernate API中,Session和Transaction接口提供了以下声明事务边界的方法: 声明事务的开始边界: Transaction tx = session.beginTransa ...

  7. hibernate框架学习第三天:对象状态、一级缓存、快照等

    对象的状态 瞬时状态: 瞬时对象(TO) 应用程序创建出来的对象,不受H3控制 注意:TO对象不具有OID,一旦为TO赋值OID,那么此时就不是TO 持久化状态:持久化对象(PO) 受H3控制的对象, ...

  8. Hibernate api 之常见的类(配置类,会话工厂类,会话类)

    1:Configuration :配置管理类对象 1.1:config.configure(): 加载主配置文件的方法(hibernate.cfg.xml) ,默认加载src/hibernate.cf ...

  9. 06-编写Hibernate API编写访问数据库的代码,使用Junit进行测试

    用到的注解: @Test:测试方法 @Before:初始化方法. @After:是否资源. 先执行Befere,然后执行Test,最后执行After. 第一步:新建一个Junit目录. 第二步:取名 ...

随机推荐

  1. Linux Shell交互式自动化运维程序

    Expect是Linux操作系统下的一个用来处理交互操作,系统默认是没有安装expect库,所以执行expect会提示找不到命令,需要手动安装,其它安装也比较简单,可以通过二进制源码包编译配置进行安装 ...

  2. jenkins 构建时显示git分支插件、显示构建分支插件

    参数化构建分支 1.安装插件:Git Parameter 2.找到我们在Jenkins中建立的工程,勾选“参数化构建过程”,并如下配置 3.在“源码管理”中如下配置 Jenkins构建完显示构建用户和 ...

  3. mysql远程不能连接问题

    解决Navicat无法连接到腾讯云MySQL的问题 工具/原料   Navicat phpstudy 腾讯云 Xshell6 方法/步骤   1 1.首先远程连接进入服务器,在cmd中输入mysql ...

  4. 洛谷P1412 经营与开发题解

    题目链接QWQ这里就不阐述了: 题解部分: 从题面上来看,这是个dp(递推)的题目. 但是dp要满足无后效性,但这个题为了取最值,得考虑从当前开始一直持续到结束的p的影响. 这让我们怎么满足无后效性? ...

  5. 如何在Linux下安装JDK1.8

    本文会详细介绍如何在Linux下安装JDK1.8 首先要设置虚拟机的IP地址,不知道如何设置的话可以 翻看我的前一篇博客   http://www.cnblogs.com/xiaoxiaoSMILE/ ...

  6. Metafile::EmfToWmfBits的使用

    其中涉及到string转换LPCWSTR以及模块绝对路径的调用 #include <iostream> #include <stdio.h> #include <WIND ...

  7. mysql参数sql_log_bin配置

    mysql参数sql_log_bin配置 如果想在主库上执行一些操作,但不复制到slave库上,可以通过修改参数sql_log_bin来实现.比如说,这里模拟主从同步复制异常. 还有一种场景,就是导入 ...

  8. python从入门到实践 第二章

    python变量赋值: python的变量赋值 可以是单引号 也可以是双引号python 变量赋值的时候不能加()的 比如 name = "My Name is GF"变量赋值的时 ...

  9. C# 之 数组倒叙排列

    //倒叙排列 string temp=""; ; i < strlist.Length / ; i++) { temp = strlist[i]; strlist[i] = ...

  10. [转] Linux多线程编程之pthread

    转载出处:https://blog.csdn.net/skyroben/article/details/72793409 1.背景知识 Linux没有真正意义上的线程,它的实现是由进程来模拟,所以属于 ...