Hibernate API的使用(Query、Criteria、SQLQuery对象)
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对象)的更多相关文章
- 五 Hibernate的其他API,Query&Criteria&SQLQuery
Query Criteria SQLQuery Query接口:用于接收HQL,用于查询多个对象 HQL:Hibernate Query Language Query条件查询: Query分页查询: ...
- [原创]java WEB学习笔记77:Hibernate学习之路---Hibernate 版本 helloword 与 解析,.环境搭建,hibernate.cfg.xml文件及参数说明,持久化类,对象-关系映射文件.hbm.xml,Hibernate API (Configuration 类,SessionFactory 接口,Session 接口,Transaction(事务))
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- Hibernate框架 初识 ORM概念 搭建Hibernate环境 Hibernate Api
ORM概念 在学习 Hibernate 之前,我们先来了解ORM 对象关系映射 O, Object 对象 R,Realtion 关系 (关系型数据库: MySQL, Oracle…) M,Ma ...
- hibernate学习之Hibernate API
1. Hibernate Api分类 1)提供访问数据库的操作(如保存,更新,删除,查询)的接口.这些接口包括:Session, Transaction,,Query接口. 2)由于配置Hiberna ...
- 【转】让EntityManager的Query返回Map对象
在JPA 2.0中我们可以使用entityManager.createNativeQuery()来执行原生的SQL语句.但当我们查询结果没有对应实体类时,需使用entityManager.create ...
- Hibernate API申明事务边界
在Hibernate API中,Session和Transaction接口提供了以下声明事务边界的方法: 声明事务的开始边界: Transaction tx = session.beginTransa ...
- hibernate框架学习第三天:对象状态、一级缓存、快照等
对象的状态 瞬时状态: 瞬时对象(TO) 应用程序创建出来的对象,不受H3控制 注意:TO对象不具有OID,一旦为TO赋值OID,那么此时就不是TO 持久化状态:持久化对象(PO) 受H3控制的对象, ...
- Hibernate api 之常见的类(配置类,会话工厂类,会话类)
1:Configuration :配置管理类对象 1.1:config.configure(): 加载主配置文件的方法(hibernate.cfg.xml) ,默认加载src/hibernate.cf ...
- 06-编写Hibernate API编写访问数据库的代码,使用Junit进行测试
用到的注解: @Test:测试方法 @Before:初始化方法. @After:是否资源. 先执行Befere,然后执行Test,最后执行After. 第一步:新建一个Junit目录. 第二步:取名 ...
随机推荐
- 学习-Pytest(五)yield操作
1.fixture的teardown操作并不是独立的函数,用yield关键字呼唤teardown操作 2.scope="module" 1.fixture参数scope=”modu ...
- java内存区域及溢出异常
内存划分: java虚拟机在执行java程序过程中会把内存分为以下区域进行管理 线程私有的 虚拟机栈 局部变量表 基本数据类型 long和double占用两个slot 对象引用 返回地址 操作数栈 动 ...
- BFPRT: O(n)最坏时间复杂度找第K大问题
同时找到最大值与最小值 找到n个元素中的最大/小值,比较次数为n-1, 找到n个元素中的最大值和最小值,可以Two Pass,比较次数为2n-2 也可以One Pass,比较次数至多为\(\left ...
- MySQL Select查询
1. 基本语法: SELECT {* | <字段列名>} [ FROM <表 1>, <表 2>… [WHERE <表达式> [GROUP BY < ...
- container_of机制
#include <stdio.h> #include <stdlib.h> /* 计算成员变量首部相对于结构变量首部的偏移量 */ #define offsetof(TYPE ...
- 基于element ui 实现七牛云自定义key上传文件,并监听更新上传进度
借助上传Upload 上传组件的 http-request 覆盖默认的上传行为,可以自定义上传的实现 <el-upload multiple ref="sliderUpload&quo ...
- thinkphp一对多关系
兹有用户表user和评论表comment 一对一 public function returnmany() { return $this->hasOne('commnet','uid','use ...
- ERROR 1040 (08004): Too many connections
ERROR 1040 (08004): Too many connections 长期一来,mysql低版本中,当面对连接数陡增而出现too many connections时,往往比较棘手.今天特意 ...
- canal 环境搭建 kafka Zookeeper安装(二)
第一步 创建Zookeeper 下载完成后 修改 Zookeeper中的 zoo.cfg 修改 dataDir .dataLogDir 集群模式 server.1=ServerIP:2888:3888 ...
- IDC装机检查思路
交换机网口 网线 配线架 服务器网口灯 系统网卡驱动