【SSM进阶之路】使用Spring SqlSessionTemplate API实现查询数据[通俗易懂]

【SSM进阶之路】使用Spring SqlSessionTemplate API实现查询数据[通俗易懂]该案例的实现是基于jar包org.mybatis.spring中的SqlSessionTemplateAPI进行使用的。主要是完成如何使用SqlSessionTemplate中的API封装一个通用的查询方法。1、首先定义一个业务层数据接口:packagecom.yihg.basic.api;importjava.util.List;importjava.util.Map;

大家好,又见面了,我是你们的朋友全栈君。

该案例的实现是基于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、定义好后若某个业务模块需要使用通用的方法进行查询数据,则需要继承公共接口。如下图:

【SSM进阶之路】使用Spring SqlSessionTemplate API实现查询数据[通俗易懂]

代码如下;

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(包括业务接口的方法),

如图所示:

【SSM进阶之路】使用Spring SqlSessionTemplate API实现查询数据[通俗易懂]

代码如下;

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)。那么公共的方法实现如下图:

【SSM进阶之路】使用Spring SqlSessionTemplate API实现查询数据[通俗易懂]

代码如下:

/**
	 * 获取查询服务
	 * 
	 * @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方法即可。实例如下图所示:

【SSM进阶之路】使用Spring SqlSessionTemplate API实现查询数据[通俗易懂]

代码如下:

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,就到这里吧!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/138416.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 单片机控制步进电机程序c语言正反转停止,51单片机控制步进电机的启动、停止、正转、反转…

    单片机控制步进电机程序c语言正反转停止,51单片机控制步进电机的启动、停止、正转、反转…51单片机控制步进电机的启动、停止、正转、反转用51单片机控制步进电机的启动、停止、正转、反转、两档速度和状态显示的目的,使步进电机控制更加灵活。步进电机驱动芯片采用ULN2803,ULN2803具有大电流、高电压,外电路简单等优点。利用四位数码管增设电机状态显示功能,各项数据更直观。实测结果表明,该控制系统达到了设计的要求。步进电机的原理图1是一种四相可变磁阻型的步进电机结构示意图。这种电机定子…

    2022年5月31日
    35
  • 计算机组成原理实验移位运算,移位运算实验

    计算机组成原理实验移位运算,移位运算实验《移位运算实验》由会员分享,可在线阅读,更多相关《移位运算实验(4页珍藏版)》请在人人文库网上搜索。1、计算机组成原理实验报告姓名吕翠学号专业计算机科学与技术班级08级师范汉班联系电话Emailqq.com同组实验者梁瑞实验室名称计算机组成原理实验室实验日期2010年10月19日课程名称计算机组成原理实验序号二实验项目移位运算实验主讲教师侯宏霞辅导教师侯…

    2022年7月13日
    13
  • redis连接时报错:Could not connect to Redis at 192.168.1.21:6379: Connection refused

    redis连接时报错:Could not connect to Redis at 192.168.1.21:6379: Connection refusedbrewinstallredis安装好redis用terminal连接redis查看状态时时出现错误:[root@admin2bin]#redis-cli-h192.168.1.21infoReplicationCouldnotconnecttoRedisat192.168.1.21:6379:Connectionrefused但是查看127.0.0…

    2022年6月3日
    41
  • Ajax 跨域,这应该是最全的解决方案了

    Ajax 跨域,这应该是最全的解决方案了

    2021年10月13日
    39
  • iOS小技能:iOS14相册权限适配 (Limited Photo Library Access)「建议收藏」

    iOS小技能:iOS14相册权限适配 (Limited Photo Library Access)「建议收藏」前言相册新增选择权限类型PHAuthorizationStatusLimited:当页面弹出请求权限Alert时,会有SelectPhotos…选项,用户选择该选项时,会弹出页面供用户选择允许App访问的图片/照片。权限提示框会在每次冷启动后打开相册时重新弹出。I、适配要点:可以在info.plist中设置PHPhotoLibraryPreventAutomaticLimitedAccessAlert选项为YES,关闭提示,PHPhotoLibraryPreventA

    2022年9月15日
    4
  • APACHE rewriterule 规则「建议收藏」

    APACHE rewriterule 规则「建议收藏」Apache/RewriteRule最最好去读官方说明。http://httpd.apache.org/docs/2.0/mod/mod_rewrite.html ——buaagengRewriteRule指令是重写引擎的根本。此指令可以多次使用。每个指令定义一个简单的重写规则。这些规则的定义顺序尤为重要——在运行时,规则是按这个顺序逐一生效的。

    2022年5月14日
    34

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号