spring 中StoredProcedure的使用方法

系统 1583 0

 StoredProcedure是一个抽象类,必须写一个子类来继承它,这个类是用来简化JDBCTemplate运行存储过程操作的。

首先我们写一个实现类:

      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));

	}



}


    


写一个測试:

      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");

		//注意有返回结果集的时候,第一个參数必须设置为返回结果集參数,不然会报错。

		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());

		}

	}
    


唯一要注意的地方就是測试里备注的地方,我測试了好久才发现,郁闷的一塌糊涂,老是莫名其妙的错,原来将參数互换一下位置就OK了,比方你把

template.setIntegerParam("@parama");写在前面然后再写template.setReturnParam("rows", new FirstReportRowMapper());的话,就会报空指针错误。

这个“rows”能够随便取名字,只是以下map.get("rows")要和你取的名字一致,由于StoredProcedureTemplate会将结果集以这个名字保存在map中返回。

还有要注意的就是设置sqlparamter的顺序要和存储过程中參数的顺序要一致,不然也会报错.

spring 中StoredProcedure的使用方法


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论