笔记:Hibernate SQL 查询
Hibernate 支持使用原生的SQL查询,使用原生SQL查询可以利用某些数据库特性,原生SQL查询也支持将SQL语句放在配置文件中配置,从而提高程序的解耦,命名SQL查询还可以用于调用存储过程。
SQL查询是通过SQLQuery接口来表示的,SQLQuery接口是Query接口的子接口,完全可以使用Query接口的方法,SQLQuery增加了二个重载方法
- addEntity():将查询到的记录与特定的实体关联
- addScalar():江查询的记录关联标量值
执行SQL的步骤如下:
- 获取Hibernate Session对象
- 编写SQL语句
- 创建SQLQuery对象,调用Session的createSQLQuery方法创建
- 调用SQLQuery对象的 addScalar 或者 addEntity 方法将选出的结果与变量值或实体进行关联
- 如果SQL语句包含参数,则调用Query的setXxx方法为参数赋值
- 调用Query的list、uniqueResult方法返回查询的结果集
- 标量查询
如果希望仅仅让Hibernate选出某个字段的值,则可以使用标量查询,通过addScalar方法指定返回的字段值,示例如下:
List list = curSession.createSQLQuery("select * FROM OneToMany_One")
.addScalar("Total_Trade_Amt", StandardBasicTypes.LONG)
.list();
- 实体查询
如果查询了某个数据表的全部数据列,且该数据表有对应的持久化类映射,可以通过 addEntity 指定持久化类型,将查询结果转换为实体,示例如下:
List list = curSession.createSQLQuery("select * FROM OneToMany_One")
.addEntity(OneToManyForOneModel.class)
.list();
- SQL参数
SQL语句可以使用二种参数定义方式,参数Key和参数索引的方式
- 参数Key方式:在SQL语句中使用":参数名称"的方式定义参数,并使用 setParameter方法的参数名称来给参数赋值,并制定参数的类型,示例如下:
List list = curSession.createSQLQuery("select * FROM OneToMany_One WHERE Record_ID = :reocrdId")
.addEntity(OneToManyForOneModel.class)
.setParameter("reocrdId", 1234, StandardBasicTypes.INTEGER)
.list();
- 参数索引方式:在SQL语句中使用"?"来定义参数,并使用setParameter方法的索引重载来给参数赋值,并制定参数的类型,示例如下:
List list = curSession.createSQLQuery("select * FROM OneToMany_One WHERE Record_ID = ?")
.addEntity(OneToManyForOneModel.class)
.setParameter(0, 1234, StandardBasicTypes.INTEGER)
.list();
- 存储过程
Hibernate 当前仅支持存储过程返回标量和实体,调用存储过程还有如下需求注意的地方:
- 建议采用标准SQL92语法,如{?=call functionName(<parameters>)} 或 {call procedureName(<parameters>)},不支持原生的调用语法。
- 调用存储过程进的查询无法使用setFirstResult()、setMaxResults()进行分页
- 定制化SQL,Hibernate 需要保存、更新和删除持久化实体时,默认通过一套固定的SQL语句来完成这些功能,如果程序需要改变这套默认的SQL语句,就可以使用Hibernate所提供的定制SQL功能,
- 注解 @SQLInsert 定制插入记录的SQL语句;
- 注解 @SQLUpdate:定制更新记录的SQL语句;
- 注解 @SQLDelete:定制删除记录的SQL语句;
- 注解 @SQLDeleteAll:定制删除所有记录的SQL语句;
- 注解@Loader:定制查询的SQL语句
他们都有二个参数,其参数sql 表示执行的定制SQL语句(存储过程),参数 callable 表示该语句是否为存储过程。如果使用存储过程时,参数的顺序很重要,可以将 org.hibernate.persister.entity 日志级别设置为 debug级别,从而允许查看Hibernate所期待的顺序,整个级别下,Hibernate将会输出 create、update和delete实体的静态SQL。因为Hibernate 会检查SQL语句是否执行成功,所以应该让存储过程能返回该存储过程影响的记录行数,Hibernate通常把CUD操作语句的第一个参数注册为数值型输出参数,所以应该让存储过程的第一个参数记录该存储过程所影响的记录条数(存储过程没有测试成功)
笔记:Hibernate SQL 查询的更多相关文章
- atitit。 hb Hibernate sql 查询使用
atitit. hb Hibernate sql 查询使用 #----------返回list<map>法..这个推荐使用. q.setResultTransformer(Tr ...
- hibernate sql查询转换成VO返回list
hibernate sql查询转换成VO @Override public List<FenxiVo> getTuanDuiFenxiList(FenxiVo FenxiVo,Intege ...
- 感恩笔记之SQL查询功能最简使用模板
感恩笔记之SQL查询功能最简使用模板 第一部分:SQL单表功能 1 语句主要关键字 SELECT --查询数据列 INTO --新建数据表 FROM --查询数据表 WHERE --筛选数据表结果 O ...
- Hibernate SQL查询 addScalar()或addEntity()
本文完全引用自: http://www.cnblogs.com/chenyixue/p/5601285.html Hibernate除了支持HQL查询外,还支持原生SQL查询. 对原 ...
- hibernate sql查询
如果你跟我一样比较熟悉SQL,同时不想学习一门新的语言.那么在hibernate中使用Native SQL 查询也是一种不错的方式. 一方面,Native SQL在效率方面有天生的优势: 另一方面,S ...
- hibernate sql查询后对象转换成实体类
在多表查询的时候使用hibernate的sql查询的时候,一般返回的是object[]数组,或者可以使用 session.createSQLQuery(sql).setResultTransform ...
- Hibernate SQL查询 addScalar()或addEntity()【转】
本文完全引用自: http://www.cnblogs.com/chenyixue/p/5601285.html Hibernate除了支持HQL查询外,还支持原生SQL查询. 对原 ...
- Hibernate SQL 查询
本文转载自:https://www.cnblogs.com/li3807/p/6358386.html Hibernate 支持使用原生的SQL查询,使用原生SQL查询可以利用某些数据库特性,原生SQ ...
- Hibernate学习笔记-Hibernate HQL查询
Session是持久层操作的基础,相当于JDBC中的Connection,通过Session会话来保存.更新.查找数据.session是Hibernate运作的中心,对象的生命周期.事务的管理.数据库 ...
随机推荐
- ASI通讯协议——ASI2x1
通讯协议--ASI2x1 基本功能描述 计算机或控制器通过以太网口或者RS232接口发出指令,包括查询指令,切换指令等,主机箱中的控制板在收到这些指令之后,将这些数据通过485总线转发给对应的主板,并 ...
- Java代码输出是“father”还是“child”(二)
1.实例 /** * 以下代码输出的结果是 */ package com.you.model; /** * @author YouHaidong * 输出的结果 */ public class Fat ...
- HashMap,LinkedHashMap,TreeMap对比
共同点: HashMap,LinkedHashMap,TreeMap都属于Map:Map 主要用于存储键(key)值(value)对,根据键得到值,因此键不允许键重复,但允许值重复. 不同点: 1.H ...
- C# 图解教程 第二章 C#编程概述
C#编程概述 一个简单的C#程序标识符关键字Main:程序的起始点从程序输出文本注释 C#编程概述 一个简单的C#程序 标识符 标识符是一种字符串,用来命名变量.方法.参数和许多后面将要阐述的其他程序 ...
- Python基础_函数2
在介绍完函数的大体概念如定义.传参.作用域之后,本节主要介绍函数的几个细节部分. 一. print()函数与return的区别. 相同点:print与return都是向用户在输出界面上展示结果 不同点 ...
- controller层中,参数的获取方式以及作用域的问题
package com.krry.web; import javax.servlet.http.HttpServletRequest; import org.springframework.stere ...
- 利用popstate事件和window下的history对象处理浏览器跳转问题
引子 之前,偶尔在项目中用过history接口做返回上一页功能,当时是用的history.go(-1),前几天面试中遇到一个控制浏览器跳转的问题时有点懵,特意查了文档记录一下,并且列出一些目前能想到的 ...
- IT企业如何实现项目管理信息化的目标
随着信息化技术的不断深入,企业管理方式逐渐向信息化管理转变.大部分IT企业也为了适应企业管理方式的变革,开始加强对管理信息化创新方面的建设.而IT企业在实现信息化的进程中,项目管理信息化其实是IT企业 ...
- PowerShell 发布farm solution
SharePoint PowerShell在SharePoint Product列表里边,然后以管理员权限启动. 1. 添加Solution 到 SharePoint Farm. Add-SPSolu ...
- openflow 和 sdn (软件定义网络) 原理和教程
OpenFlow概述 OpenFlow简介 通俗的讲,OpenFlow是使用类似于API进程配置网络交换机的协议.OpenFlow的思路很简单,网络设备维护一个FlowTable并且只按照FlowTa ...