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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 二叉树层序遍历Java版

    二叉树层序遍历Java版publicList<List<Integer>>levelOrder(TreeNoderoot){List<List<Integer>>result=newArrayList<>();if(root==null)returnresult;List<TreeNode>queue=newArrayList<>();queue.add(root);

  • c语言小游戏百度云资源,c语言小游戏合集

    c语言小游戏百度云资源,c语言小游戏合集这是c语言小游戏合集下载,这是我用c语言写的程序,我在大三上学期的劳动成果展示。我的其他资源都是免费的,是对于c语言初学者的帮助比较大的,其中有数据结构,window编程。我也在学c语言,每当我写完一个程序,我都会免费发上来。软件介绍c语言小游戏合集是本人在网上搜集的C语言编写的经典小游戏的源码集合,有志于C游戏编程学习的朋友可以选用参考。软件说明100个比较经典的C语言代码分享给大家,我都加了注…

  • 如何正确安装Oracle:Oracle11g安装教程

    如何正确安装Oracle:Oracle11g安装教程前言之前安装的过程中存在隐患问题,所以导致了我把它狠心的卸载了,今天就正确的安装上我们的Oracle。怎么卸载?卸载请点这里下面我们就来看一看具体的实施步骤吧!首先开水烫毛,将脏器取出,放上葱姜蒜等香料…下…锅…不好意思,走错片场了下载没有安装包,等我给你下载呐?好吧,这次就帮你一次吧!官方下地址:甲骨文官网如果你不想忍受英文的肆虐,那么直接点下面的连接吧!win3…

  • 中国软件开发外包公司排名-国内最大的软件开发商有哪些呢

    中国软件开发外包公司排名-国内最大的软件开发商有哪些呢中国软件开发外包公司排名-国内最大的软件开发商有哪些呢

  • pycharm py文件运行后停止按钮变成了灰色[通俗易懂]

    pycharm py文件运行后停止按钮变成了灰色[通俗易懂]这两天被这个问题折磨得要死,把pycharm卸载了还是没解决,后来终于在一篇博客中看见,然后终于解决了问题界面如下:1.每次运行后都会跳出一个pythonconsole,并且前面还会显示一大堆奇怪信息:importsys;print(‘Python%son%s’%(sys.version,sys.platform))sys.path.extend2.右上角…

  • windows软连接简单建立删除「建议收藏」

    软连接基本命令:建立(mklink),删除(rmdir);基本场景:1将电脑F盘下目录bpe\source下文件aa.txt和文件夹bb通过软连接连接至目录bpe\dest下1.1命令语句:mklink/JF:\bpe\dest\aa.txt       F:\bpe\icc\source\aa.txtmklink/JF:\bpe\dest\bb …

发表回复

您的电子邮箱地址不会被公开。

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