欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

spring 中StoredProcedure的使用方法

系統(tǒng) 1738 0

?StoredProcedure是一個(gè)抽象類,必須寫一個(gè)子類來(lái)繼承它,這個(gè)類是用來(lái)簡(jiǎn)化JDBCTemplate運(yùn)行存儲(chǔ)過程操作的。

首先我們寫一個(gè)實(shí)現(xiàn)類:

      package com.huaye.framework.dao;



import java.sql.Types;

import java.util.HashMap;

import java.util.Map;



import org.springframework.jdbc.core.RowMapper;

import org.springframework.jdbc.core.SqlOutParameter;

import org.springframework.jdbc.core.SqlParameter;

import org.springframework.jdbc.core.SqlReturnResultSet;

import org.springframework.jdbc.object.StoredProcedure;



/**

 * Name:StoredProcedureTemplate User: HP Date: 2007-7-21 Time: 7:40:01

 * Description:

 */

public class StoredProcedureTemplate extends StoredProcedure {



	private HashMap<String, Object> map = new HashMap<String, Object>();



	public StoredProcedureTemplate() {

		super();



	}



	

	public HashMap getMap()

	{

		return this.map;

	}

	

	public void setValue(String key, Object obj) {

		map.put(key, obj);

	}



	public Map execute() {

		if (this.getSql() == null || this.getSql().equals(""))

			return null;

		this.compile();

		return execute(map);

	}



	public void setVarcharParam(String param) {

		this.declareParameter(new SqlParameter(param, Types.VARCHAR));

	}



	public void setDoubleParam(String param) {

		this.declareParameter(new SqlParameter(param, Types.DOUBLE));

	}



	public void setIntegerParam(String param) {

		this.declareParameter(new SqlParameter(param, Types.INTEGER));

	}



	public void setVarcharOutParam(String param) {

		this.declareParameter(new SqlOutParameter(param, Types.VARCHAR));

	}



	public void setDoubleOutParam(String param) {

		this.declareParameter(new SqlOutParameter(param, Types.DOUBLE));

	}



	public void setIntegerOutParam(String param) {

		this.declareParameter(new SqlOutParameter(param, Types.INTEGER));

	}





	public void setInParam(String param,int valueType)

	{

		this.declareParameter(new SqlParameter(param, valueType));

		

	}

	

	public void setOutParam(String param,int valueType)

	{

		this.declareParameter(new SqlOutParameter(param, valueType));

		

	}

	

	public void setReturnParam(String param, RowMapper rowMapper) {

		this.declareParameter(new SqlReturnResultSet(param,rowMapper));

	}



}


    


寫一個(gè)測(cè)試:

      public void test2() {

		ApplicationContext context = new ClassPathXmlApplicationContext(

				"classpath:spring/applicationContext-base.xml");

		JdbcTemplate jdbc = (JdbcTemplate) context.getBean("jdbcTemplate");



		StoredProcedureTemplate template = new StoredProcedureTemplate();

		

		template.setJdbcTemplate(jdbc);

		template.setSql("testproc");

		//注意有返回結(jié)果集的時(shí)候,第一個(gè)參數(shù)必須設(shè)置為返回結(jié)果集參數(shù),不然會(huì)報(bào)錯(cuò)。

		template.setReturnParam("rows", new FirstReportRowMapper());

		

		template.setIntegerParam("@parama");

		

		template.setValue("@parama", 9);

		

		Map map = template.execute();

		Object o = map.get("rows");

		List<FirstReportVO> list = (List<FirstReportVO>)o;

		for (FirstReportVO vo : list) {

			System.out.println(vo.getSortID()+","+vo.getSortName());

		}

	}
    


唯一要注意的地方就是測(cè)試?yán)飩渥⒌牡胤剑覝y(cè)試了好久才發(fā)現(xiàn),郁悶的一塌糊涂,老是莫名其妙的錯(cuò),原來(lái)將參數(shù)互換一下位置就OK了,比方你把

template.setIntegerParam("@parama");寫在前面然后再寫template.setReturnParam("rows", new FirstReportRowMapper());的話,就會(huì)報(bào)空指針錯(cuò)誤。

這個(gè)“rows”能夠隨便取名字,只是以下map.get("rows")要和你取的名字一致,由于StoredProcedureTemplate會(huì)將結(jié)果集以這個(gè)名字保存在map中返回。

還有要注意的就是設(shè)置sqlparamter的順序要和存儲(chǔ)過程中參數(shù)的順序要一致,不然也會(huì)報(bào)錯(cuò).

spring 中StoredProcedure的使用方法


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 国产一区二区黑人欧美xxxx | 三人弄娇妻高潮3p视频 | 日韩福利网站 | 91中文字幕在线一区 | 久久精品伊人网 | 被摁着灌浓精囚禁高h1v1 | 久久久久无码国产精品一区 | 亚洲精品自产拍在线观看app | 黄色特级一级片 | 一级片片 | 天天碰天天操 | 亚洲综合图片色婷婷另类小说 | 草草视频在线观看 | 亚洲情a成黄在线观看动 | 日日操夜夜操免费视频 | 国内精品免费一区二区观看 | 天天操91 | 国产精品美女一区二区三区 | 欧美视频精品 | 亚洲精品久久久久无码AV片软件 | 91中文视频 | 精品国产不卡一区二区三区 | 久久噜噜噜精品国产亚洲综合 | 精品小视频在线观看 | 精品国产一区二区在线 | 四虎在线视频 | 欧美在线观看视频 | 欧美区在线 | 男女视频免费在线观看 | 亚洲国产日韩在线观频 | 亚洲第一大网站 | 亚洲自拍另类 | 夜夜操夜夜骑 | 性夜影院爽黄e爽在线观看 苏晓晖个人简介军衔 | 亚洲精品久久久久久一区 | 2022最新a精品视频在线观看 | 男女污污无遮挡免费观看 | 午夜久久久久久禁播电影 | 国产亚洲欧美在线 | 欧美日韩大片在线观看 | 四虎影视在线影院在线观看观看 |