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

    ?
    ?

  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操作语句的第一个参数注册为数值型输出参数,所以应该让存储过程的第一个参数记录该存储过程所影响的记录条数(存储过程没有测试成功)

时间: 2024-10-23 18:55:04

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

atitit。 hb Hibernate sql 查询使用

atitit. hb  Hibernate sql 查询使用 #----------返回list<map>法..这个推荐使用. q.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); List li=q.list(); 作者 老哇的爪子 Attilax 艾龙,  EMAIL:[email protected] 转载请注明来源: http://blog.csdn.net/attilax #------------------默认obje

hibernate sql查询对象到map中

转载请注明出处:http://blog.csdn.net/ruoyunliufeng/article/details/26059615 插入排序:它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入. 一.插入排序算法 /*************************************************************** *版权所有 (C)2014,公司名称. * *文件名称:插入排序法 *内容摘要:无 *其它说明:无 *当前版

hibernate sql查询

如果你跟我一样比较熟悉SQL,同时不想学习一门新的语言.那么在hibernate中使用Native SQL 查询也是一种不错的方式. 一方面,Native SQL在效率方面有天生的优势: 另一方面,SQL是数据库操作的一种标准,我们与程序.数据库关联很小.如果将来不用hibernate,而是用别的ORM,sql一样好用. 但尽量用标准SQL,而不要用过多方言SQL. 标量查询 最基本的 SQL 查询就是获得一个标量(数值)的列表. sess.createSQLQuery("SELECT * FR

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

在多表查询的时候使用hibernate的sql查询的时候,一般返回的是object[]数组,或者可以使用 session.createSQLQuery(sql).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);     session. session.createSQLQuery(sql).addEntity(entity.class); /**     * 分页查询sql,sql语句不包含起始记录数和查询记录数     * @pa

hibernate sql查询转化为实体类

在多表查询的时候使用hibernate的sql查询的时候,一般返回的是object[]数组,或者可以使用 session.createSQLQuery(sql).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); 来转化为map来进行处理,可以通过以下方式将查询结果转化为实体类: 1,sql语句 String sql="select s.id as id,s.classname as classname from grade s,stu

Hibernate SQL查询 addScalar()或addEntity()

Hibernate除了支持HQL查询外,还支持原生SQL查询.          对原生SQL查询执行的控制是通过SQLQuery接口进行的,通过执行Session.createSQLQuery()获取这个接口.该接口是Query接口的子接口.          执行SQL查询步骤如下:          1.获取Hibernate Session对象          2.编写SQL语句          3.通过Session的createSQLQuery方法创建查询对象         

【知了堂学习笔记】SQL查询基础语句(单表查询、多表查询)

SQL查询基础 1.单表查询 从数据库中查找数据 专业的称谓又称为投影 基本查询语句结构 select 列 from 表 * 所有列不是所有其他东西 查询所有数据 例:SELECT * FROM t_studen 需要执行比较细的操作  加上条件筛选:查询id为2号的学生信息 SELECT * FROM t_student WHERE id=2; 筛选的执行步骤 例:SELECT * FROM t_student WHERE id=2; SELECT *          (3) 再查询  筛选

Java学习笔记-Hibernate HQL查询

Session是持久层操作的基础,相当于JDBC中的Connection,通过Session会话来保存.更新.查找数据.session是Hibernate运作的中心,对象的生命周期.事务的管理.数据库的存取都与Session有关Session由SessionFactory创建,是线程安全的Thread-Safe,可以让多个线程同时存取SessionFactory而不会有数据共享的问题 Hibernate中Session的解释 :http://blog.csdn.net/shrek_xu/arti

Thinkphp随堂笔记【sql查询语句】

THINKPHP中sql提供以下查询语句 //字符串sql安全系数太低 例如配合M方法使用: $user = M('User'); //var_dump($user->where('id=1 || user="蜡笔小新"')->select()); //使用数组索引的方式安全得多 //$condition['id']=1; //$condition['user']="蜡笔小新"; //$condition['_logic']='OR'; //var_du