标签:eal 接口 调用 静态 获取 保存 允许 asi procedure
Hibernate 支持使用原生的SQL查询,使用原生SQL查询可以利用某些数据库特性,原生SQL查询也支持将SQL语句放在配置文件中配置,从而提高程序的解耦,命名SQL查询还可以用于调用存储过程。
SQL查询是通过SQLQuery接口来表示的,SQLQuery接口是Query接口的子接口,完全可以使用Query接口的方法,SQLQuery增加了二个重载方法
执行SQL的步骤如下:
? ?
如果希望仅仅让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语句可以使用二种参数定义方式,参数Key和参数索引的方式
List list = curSession.createSQLQuery("select * FROM OneToMany_One WHERE Record_ID = :reocrdId")
.addEntity(OneToManyForOneModel.class)
.setParameter("reocrdId", 1234, StandardBasicTypes.INTEGER)
.list();
? ?
List list = curSession.createSQLQuery("select * FROM OneToMany_One WHERE Record_ID = ?")
.addEntity(OneToManyForOneModel.class)
.setParameter(0, 1234, StandardBasicTypes.INTEGER)
.list();
Hibernate 当前仅支持存储过程返回标量和实体,调用存储过程还有如下需求注意的地方:
他们都有二个参数,其参数sql 表示执行的定制SQL语句(存储过程),参数 callable 表示该语句是否为存储过程。如果使用存储过程时,参数的顺序很重要,可以将 org.hibernate.persister.entity 日志级别设置为 debug级别,从而允许查看Hibernate所期待的顺序,整个级别下,Hibernate将会输出 create、update和delete实体的静态SQL。因为Hibernate 会检查SQL语句是否执行成功,所以应该让存储过程能返回该存储过程影响的记录行数,Hibernate通常把CUD操作语句的第一个参数注册为数值型输出参数,所以应该让存储过程的第一个参数记录该存储过程所影响的记录条数(存储过程没有测试成功)
标签:eal 接口 调用 静态 获取 保存 允许 asi procedure
原文地址:http://www.cnblogs.com/li3807/p/6358386.html