【SSM进阶之路】使用Spring SqlSessionTemplate API实现查询数据

14 篇文章 0 订阅

该案例的实现是基于jar包org.mybatis.spring中的SqlSessionTemplate API进行使用的。主要是完成如何使用SqlSessionTemplate中的API封装一个通用的查询方法。

1、首先定义一个业务层数据接口:

package com.yihg.basic.api;

import java.util.List;
import java.util.Map;

import com.yihg.mybatis.utility.PageBean;

/**
 * 通用查询
 * 
 * @author zhangsq
 * @create 2016年12月09日 上午9:27:43
 */
public interface CommonService {
	
	/**
	 * 分页列表查询
	 * 
	 * @author zhangsq
	 * @create 2016年12月09日 上午9:28:36
	 * @param sqlId 查询语句ID
	 * @param pageBean 分页参数 或者 查询条件
	 * @return
	 */
	PageBean queryListPage(String sqlId, PageBean pageBean);

	/**
	 * 列表查询
	 * 
	 * @author zhangsq
	 * @create 2016年12月09日 上午9:28:43
	 * @param sqlId 查询语句ID
	 * @param param 查询条件
	 * @return
	 */
	List queryList(String sqlId, Map param);
	
	/**
	 * 对象查询
	 * 
	 * @author zhangsq
	 * @create 2016年12月09日 上午9:28:43
	 * @param sqlId 查询语句ID
	 * @param param 查询条件
	 * @return
	 */
	Map queryOne(String sqlId, Map param);

}
2、定义好后若某个业务模块需要使用通用的方法进行查询数据,则需要继承公共接口。如下图:


代码如下;

package com.yihg.sales.api;

import com.yihg.basic.api.CommonService;

/**
 * 通用查询
 * 
 * @author zhansgsq
 * @create 2016年12月09日 下午6:41:33
 */
public interface CommonSaleService extends CommonService{

}


3、定义一个相关业务模块的业务实现类CommonServiceImpl,该类需要实现业务接口类CommonSaleService(包括业务接口的方法),

如图所示:


代码如下;

package com.yihg.sales.impl;

import java.util.List;
import java.util.Map;

import org.mybatis.spring.SqlSessionTemplate;
import org.springframework.beans.factory.annotation.Autowired;

import com.yihg.mybatis.utility.PageBean;
import com.yihg.sales.api.CommonSaleService;

/**
 * 通用查询
 * 
 * @author zhangsq
 * @create 2016年12月09日 上午9:34:18
 */
public class CommonServiceImpl implements CommonSaleService {

	@Autowired
	private SqlSessionTemplate ss;

	@Override
	public PageBean queryListPage(String sqlId, PageBean pageBean) {
		
		pageBean.setResult(ss.selectList(sqlId, pageBean));
		return pageBean;
	}

	@Override
	public List queryList(String sqlId, Map param) {
		return ss.selectList(sqlId, param);
	}
	
	@Override
	public Map queryOne(String sqlId, Map param) {
		return ss.selectOne(sqlId, param);
	}
}


4、然后在控制层Controller中定义一个公共的方法以供多处调到,该方法主要是获取查询服务,即可从SpringApplicationContext(org.springframework.context.ApplicationContext)中获取Spring管理的Service,该Service也就是CommonServiceImpl(在Spring Bean中是commonService)。那么公共的方法实现如下图:


代码如下:

/**
	 * 获取查询服务
	 * 
	 * @author zhangsq
	 * @create 2016年12月09日 上午9:34:25
	 * @param svc
	 * @return
	 */
	private CommonService getCommonService(String svc) {
		if (StringUtils.isBlank(svc)) {
			svc = "commonsaleService";
		}
		return appContext.getBean(svc, CommonService.class);
	}


5、最后在相关的Controller请求方法中直接调用上面的getCommonService方法即可。实例如下图所示:


代码如下:

PageBean pb = new PageBean();
		pb.setPage(page);
		if (pageSize == null) {
			pageSize = Constants.PAGESIZE;
		}
		pb.setPageSize(pageSize);
		........
		........
		........
		Map<String, Object> pms = WebUtils.getQueryParamters(request);
		pb.setParameter(pms);
		pb = getCommonService(svc).queryListPage(sl, pb);
		model.addAttribute("pageBean", pb);

其中PageBean类是封装了分页的属性以及方法。sl参数的格式为:mapper.xml中的namespace值.sql方法名 如:booking.bookingXXXXXXListPage

代码中使用model将查询的结果返回了,在页面上直接使用循环标签对“PageBean”进行循环获取数据即可。


KO,就到这里吧!!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张思全

实践,方能出真知!打赏博主吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值