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

【SSM进阶之路】使用Spring SqlSessionTemplate API实现查询数据[通俗易懂]该案例的实现是基于 jar 包 org mybatis spring 中的 SqlSessionTe API 进行使用的 主要是完成如何使用 SqlSessionTe 中的 API 封装一个通用的查询方法 1 首先定义一个业务层数据接口 package com yihg basic api import java util List import java 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、定义好后若某个业务模块需要使用通用的方法进行查询数据,则需要继承公共接口。如下图:

代码如下;

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

编程小号
上一篇 2025-01-29 21:33
下一篇 2025-01-27 10:33

相关推荐

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