1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > jpa调用mysql函数_Spring data jpa 调用存储过程处理返回参数及结果集(示例代码)

jpa调用mysql函数_Spring data jpa 调用存储过程处理返回参数及结果集(示例代码)

时间:2023-10-13 01:01:55

相关推荐

jpa调用mysql函数_Spring data jpa 调用存储过程处理返回参数及结果集(示例代码)

一、环境

1.此随笔内容基于spring boot整合的spring data jpa项目,

2.数据库为mysql 5.7.9版本

二、内容

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注解绑定存储过程

@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. 结果处理

publicResultInfo queryInitGeneral(String themeCode) {

ResultInfo resultInfo = newResultInfo();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("查询成功!");

returnresultInfo;

}

在调用过程中,使用StoredProcedureQuery中的getResultList()方法可以返回存储过程执行之后的结果集(此处的结果集是一个,多个还未实验);然后使用storedProcedureQuery的 getOutputParameterValue() 方法可以返回out 参数

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。