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方法返回查询的结果集

     
     

  1. 标量查询

    如果希望仅仅让Hibernate选出某个字段的值,则可以使用标量查询,通过addScalar方法指定返回的字段值,示例如下:

    List list = curSession.createSQLQuery("select * FROM OneToMany_One")

    .addScalar("Total_Trade_Amt", StandardBasicTypes.LONG)

    .list();

  2. 实体查询

    如果查询了某个数据表的全部数据列,且该数据表有对应的持久化类映射,可以通过 addEntity 指定持久化类型,将查询结果转换为实体,示例如下:

    List list = curSession.createSQLQuery("select * FROM OneToMany_One")

    .addEntity(OneToManyForOneModel.class)

    .list();

  3. 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();

  1. 存储过程

    Hibernate 当前仅支持存储过程返回标量和实体,调用存储过程还有如下需求注意的地方:

  • 建议采用标准SQL92语法,如{?=call functionName(<parameters>)} 或 {call procedureName(<parameters>)},不支持原生的调用语法。
  • 调用存储过程进的查询无法使用setFirstResult()、setMaxResults()进行分页
  1. 定制化SQL,Hibernate 需要保存、更新和删除持久化实体时,默认通过一套固定的SQL语句来完成这些功能,如果程序需要改变这套默认的SQL语句,就可以使用Hibernate所提供的定制SQL功能,
    1. 注解 @SQLInsert 定制插入记录的SQL语句;
    2. 注解 @SQLUpdate:定制更新记录的SQL语句;
    3. 注解 @SQLDelete:定制删除记录的SQL语句;
    4. 注解 @SQLDeleteAll:定制删除所有记录的SQL语句;
    5. 注解@Loader:定制查询的SQL语句

    他们都有二个参数,其参数sql 表示执行的定制SQL语句(存储过程),参数 callable 表示该语句是否为存储过程。如果使用存储过程时,参数的顺序很重要,可以将 org.hibernate.persister.entity 日志级别设置为 debug级别,从而允许查看Hibernate所期待的顺序,整个级别下,Hibernate将会输出 create、update和delete实体的静态SQL。因为Hibernate 会检查SQL语句是否执行成功,所以应该让存储过程能返回该存储过程影响的记录行数,Hibernate通常把CUD操作语句的第一个参数注册为数值型输出参数,所以应该让存储过程的第一个参数记录该存储过程所影响的记录条数(存储过程没有测试成功)

笔记:Hibernate SQL 查询的更多相关文章

  1. atitit。 hb Hibernate sql 查询使用

    atitit. hb  Hibernate sql 查询使用 #----------返回list<map>法..这个推荐使用.      q.setResultTransformer(Tr ...

  2. hibernate sql查询转换成VO返回list

    hibernate sql查询转换成VO @Override public List<FenxiVo> getTuanDuiFenxiList(FenxiVo FenxiVo,Intege ...

  3. 感恩笔记之SQL查询功能最简使用模板

    感恩笔记之SQL查询功能最简使用模板 第一部分:SQL单表功能 1 语句主要关键字 SELECT --查询数据列 INTO --新建数据表 FROM --查询数据表 WHERE --筛选数据表结果 O ...

  4. Hibernate SQL查询 addScalar()或addEntity()

    本文完全引用自: http://www.cnblogs.com/chenyixue/p/5601285.html Hibernate除了支持HQL查询外,还支持原生SQL查询.          对原 ...

  5. hibernate sql查询

    如果你跟我一样比较熟悉SQL,同时不想学习一门新的语言.那么在hibernate中使用Native SQL 查询也是一种不错的方式. 一方面,Native SQL在效率方面有天生的优势: 另一方面,S ...

  6. hibernate sql查询后对象转换成实体类

    在多表查询的时候使用hibernate的sql查询的时候,一般返回的是object[]数组,或者可以使用  session.createSQLQuery(sql).setResultTransform ...

  7. Hibernate SQL查询 addScalar()或addEntity()【转】

    本文完全引用自: http://www.cnblogs.com/chenyixue/p/5601285.html Hibernate除了支持HQL查询外,还支持原生SQL查询.          对原 ...

  8. Hibernate SQL 查询

    本文转载自:https://www.cnblogs.com/li3807/p/6358386.html Hibernate 支持使用原生的SQL查询,使用原生SQL查询可以利用某些数据库特性,原生SQ ...

  9. Hibernate学习笔记-Hibernate HQL查询

    Session是持久层操作的基础,相当于JDBC中的Connection,通过Session会话来保存.更新.查找数据.session是Hibernate运作的中心,对象的生命周期.事务的管理.数据库 ...

随机推荐

  1. 利用 jQuery 来验证密码两次输入是否相同

    html <div class="row"> <div class="panel panel-info"> <div class= ...

  2. java Socket实现简单在线聊天(三)

    在上一篇,利用线程使服务端实现了能够接收多客户端请求的功能,这里便需要客户端接收多客户端消息的同时还能把消息转发到每个连接的客户端,并且客户端要能在内容显示区域显示出来,从而实现简单的在线群聊. 在实 ...

  3. JavaScript获取屏幕和页面的宽度和高度

    JavaScript获取屏幕和页面的宽度和高度 1.设计源码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN ...

  4. echarts中的option.legend.data has not been defined.

    1.错误描述 2.错误原因 var map = function(mapData){ require( [ 'echarts', 'echarts/chart/map' ], function (ec ...

  5. AM335x(TQ335x)学习笔记——触摸屏驱动编写

    前面几篇文章已经通过配置DTS的方式完成了多个驱动的移植,接下来我们解决TQ335x的触摸驱动问题.由于种种原因,TQ335x的触摸屏驱动是以模块方式提供的,且Linux官方内核中也没有带该触摸屏的驱 ...

  6. 利用Tomcat部署Web项目报错

    1.错误描述 usage: java org.apache.catalina.startup.Catalina [ -config {pathname} ] [ -nonaming ] { -help ...

  7. Regex 正则替换指定范围全部字符串

    1.正则替换字符-------------------------------------------------------------------------------------------- ...

  8. jquery.lazyload.js实现图片懒加载

    个人理解:将需要延迟加载的图片的src属性全部设置为一张相同尽可能小(目的是尽可能的少占宽带,节省流量,由于缓存机制,当浏览器加载了一张图片之后,相同的图片就会在缓存中拿,不会重新到服务器上拿)的图片 ...

  9. hdu5893 List wants to travel

    裸的树链剖分加线段树区间修改 区间合并时需要多注意一点 当时写的很慢 理解不深刻 #include<bits/stdc++.h> using namespace std; const in ...

  10. 【SoDiaoEditor电子病历编辑器】编辑器支持移动化

    写在前面 每次写SoDiao时都是一次灵魂拷问,这么猥琐的名字,会对程序媛产生多少误导啊,我是一个正直的人,不管你信不信每个见到我的人都这么说.本次更新拖了很久,本来半个月前应该实现的,却一直拖到昨天 ...