Springmvc調(diào)用存儲(chǔ)過程,并返回存儲(chǔ)過程返還的數(shù)據(jù)方式
Springmvc調(diào)用存儲(chǔ)過程,并返回存儲(chǔ)過程返還的數(shù)據(jù)
java后端很多時(shí)候都需要和數(shù)據(jù)庫進(jìn)行交互,并返回業(yè)務(wù)數(shù)據(jù)。一般情況下都會(huì)采用執(zhí)行SQL的方式來進(jìn)行交互,但有些特別的場(chǎng)景時(shí),也可以直接利用存儲(chǔ)過程返回?cái)?shù)據(jù)。
存儲(chǔ)過程返回?cái)?shù)據(jù)的好處是只需要一個(gè)調(diào)用,即可根據(jù)不同的參數(shù)返回不同的業(yè)務(wù)數(shù)據(jù),這些業(yè)務(wù)數(shù)據(jù)有可能列名完全不一樣。
實(shí)現(xiàn)如下
首先要先定義SqlMap.xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd" >
<sqlMap namespace="YJSPGJ">
<parameterMap id="yjspgj_test" class="java.util.Map">
<parameter property="v_dxlx" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN" />
<parameter property="i_qsrq" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN" />
</parameterMap>
<procedure id="yjspgj_test" resultClass="java.util.HashMap" remapResults="true" parameterMap="yjspgj_test">
{call sp_test_returnmap(?,?)}
</procedure>
</sqlMap>
這里要重點(diǎn)說明一下
1、返回的resultClass="java.util.HashMap",一定要是HashMap,如果直接寫Map的話會(huì)報(bào)錯(cuò),因?yàn)镸ap是一個(gè)接口,不能對(duì)接口進(jìn)行實(shí)例化,HashMap是一個(gè)類,可以進(jìn)行實(shí)例化。
2、一定要加上remapResults="true",否則的話當(dāng)存儲(chǔ)過程返回的列不一致時(shí),會(huì)導(dǎo)致系統(tǒng)報(bào)錯(cuò)。
定義基礎(chǔ)類api:
public interface YjspgjService {
String KEY="yjspgj.YjspgjService";
public ResultCommon selectTest(Map<String,Object> map);
}
定義實(shí)現(xiàn)類service:
@Service(YjspgjService.KEY)
public class YjspgjServiceImpl extends SubService implements YjspgjService {
@Autowired
private YjspgjDao yjspgjDao;
public ResultCommon selectTest(Map<String, Object> map) {
// TODO Auto-generated method stub
ResultListData result=new ResultListData(PasCloudCode.SUCCESS);
List listData=yjspgjDao.selectTest(map);
result.setRows(listData);
return result;
}
}
定義數(shù)據(jù)庫操作類dao:
@Repository
public class YjspgjDao {
private static final Logger log = LoggerFactory.getLogger(YjspgjDao.class);
@Autowired
private IBaseDAO ibaseDAO;
public List selectTest(Map<String,Object> map){
String sqlKey="yjspgj_test";
return (List)ibaseDAO.selectInfoByPara(sqlKey, map);
}
}
調(diào)用controller:
@Controller
@RequestMapping("/yjspgj")
public class YjspgjController extends BaseController {
@Autowired
YjspgjService yjspgjService;
private static Gson gson = new GsonBuilder().serializeNulls().create();//用于json格式的轉(zhuǎn)化
@RequestMapping("/showData")
@ResponseBody
public void showData(HttpServletRequest request, HttpServletResponse response){
Map<String,Object> map=new HashMap();
setMap(map,request);//自行定義Map的值
ResultListData rc= (ResultListData) yjspgjService.selectTest(map);
List list=rc.getRows();
for(int i=0;i<list.size();i++){
try {
response.getWriter().write(list.get(i).toString()+"\n");
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
@Override
protected Class setClass() {
// TODO Auto-generated method stub
return this.getClass();
}
}
Springmvc調(diào)用存儲(chǔ)過程,entity文件寫法
<!--廣告任務(wù)申請(qǐng),被審核通過-->
<select id="approveAdTask" statementType="CALLABLE" parameterType="java.util.Map">
{call approveAdTask(
#{sn,mode=IN,jdbcType=VARCHAR}
,#{ssn,mode=IN,jdbcType=VARCHAR}
,#{psn,mode=IN,jdbcType=VARCHAR}
,#{sname,mode=IN,jdbcType=VARCHAR})}
</select>
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java中實(shí)現(xiàn)List分隔成子List詳解
大家好,本篇文章主要講的是Java中實(shí)現(xiàn)List分隔成子List詳解,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
GC算法實(shí)現(xiàn)篇之并發(fā)標(biāo)記清除
這篇文章主要為大家介紹了GC算法實(shí)現(xiàn)篇之并發(fā)-標(biāo)記-清除,?CMS垃圾收集器在減少停頓時(shí)間上做了很多給力的工作,?大量的并發(fā)線程執(zhí)行的工作并不需要暫停應(yīng)用線程2022-01-01
springcloud安裝rabbitmq并配置延遲隊(duì)列插件的過程詳解
本期主要講解如何利用docker快速安裝rabbitmq并且配置延遲隊(duì)列插件,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05
使用springBoot項(xiàng)目配置文件位置調(diào)整到打包外
Java實(shí)現(xiàn)手寫乞丐版線程池的示例代碼
出現(xiàn)java.lang.NoSuchMethodException異常的解決(靠譜)

