1、环境java
1.此随笔内容基于spring boot整合的spring data jpa项目,mysql
2.数据库为mysql 5.7.9版本 spring
2、内容sql
1. 新建存储过程 pro_query_object数据库
BEGIN #Routine body goes here...a_theme_code varchar(10),out num int select o.obj_code,o.obj_name,o.obj_id from qt_object o where o.theme_code=a_theme_code; select count(*) into num from qt_object o where o.theme_code=a_theme_code GROUP BY o.theme_code; END
2. 新建实体,首先把咱们须要返回的结果集的实体字段定义好,而后加上@NamedStoredProcedureQueries 注解绑定存储过程this
-
@Entity @NamedStoredProcedureQueries({ //管理列表 @NamedStoredProcedureQuery(name = "pro_general_list", procedureName = "pro_general_list", resultClasses = { QtObject.class }, parameters = { @StoredProcedureParameter(mode = ParameterMode.IN, name = "a_theme_code", type = String.class), @StoredProcedureParameter(mode = ParameterMode.OUT, name = "num", type = Integer.class) // 记录知足条件的总条数 }), }) public class QtObject { @Id @Column(name = "obj_id") private String objId; private String obj_code; private String obj_name; // 此处省略get、set }
此处: - @NamedStoredProcedureQueries 内可写多个存储过程,使用“,”隔开;
@NamedStoredProcedureQuery
中
procedureName参数是数据库中存储过程的名字;- name参数是JPA中的存储过程的名字;resultClasses参数是返回结果集绑定的实体名称(处理结果集重要参数);
parameters
中使用
@StoredProcedureParameter来定义存储过程使用的IN、OUT参数。
/// 调用存储过程
3.完成实体后,咱们在编写调用方法
public StoredProcedureQuery callStore(String themeCode) { StoredProcedureQuery store = this.entityManager.createNamedStoredProcedureQuery("pro_general_list"); store.setParameter("a_theme_code", themeCode); store.execute(); return store; }
调用存储过程时,须要先注入实体管理器EntityManager,调用其中的 createNamedStoredProcedureQuery方法,传入jpa 的存储过程名称,而后只须要传入in 参数,执行以后返回StoredProcedureQuery对象。
4. 结果处理
public ResultInfo queryInitGeneral(String themeCode) { ResultInfo<List> resultInfo = new ResultInfo<List>(); StoredProcedureQuery storedProcedureQuery= callStore(start_date, end_date,themeCode,deptCode,obj_name,start_num,end_num); Integer nums = (Integer)storedProcedureQuery.getOutputParameterValue("num"); resultInfo.setRows(storedProcedureQuery.getResultList()); resultInfo.setTotal(nums); resultInfo.setResult(1); resultInfo.setMsg("查询成功!"); return resultInfo; }
在调用过程当中,使用StoredProcedureQuery中的getResultList()方法能够返回存储过程执行以后的结果集(此处的结果集是一个,多个还未实验);而后使用storedProcedureQuery的 getOutputParameterValue() 方法能够返回out 参数