之前我们讲的基于XML还是接口注解配置都是使用接口实现CRUD,本文我们将要讲解通过splsession来实现CRUD,这种方法比较灵活。

基本配置

  <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath:mapping/*.xml"></property>
<!-- 分页插件 -->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageHelper">
<property name="properties">
<value>
dialect=mysql
</value>
</property>
</bean>
</array>
</property>
</bean> <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="0" ref="sqlSessionFactory" />
</bean>

Mapper实现

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="sysUserMapper">
<select id="SelectOne" parameterType="java.util.HashMap" resultType="java.util.HashMap">
select * from user_ where id = #{id,jdbcType=VARCHAR} limit 0,20
</select>
<select id="SelectProc" parameterType="java.util.HashMap" resultType="java.util.HashMap" >
{call get_user(#{id,jdbcType=VARCHAR})}
</select>
<select id="SelectList" parameterType="java.util.HashMap" resultType="java.util.HashMap" >
select * from user_
<where>
<if test="male_ != null and male_!=''">
AND male_ = #{male_,jdbcType=VARCHAR}
</if>
</where>
limit 0,20
</select>
<insert id="insert" parameterType="java.util.HashMap">
insert into user_test(id, name) values(#{id}, #{name})
</insert>
</mapper>

数据实现

首先我们 添加SqlSession 属性注入

 @Autowired
private SqlSession sqlSession;

然后我们实现具体的CRUD操作

 public Map<String, String> SelectOne(String method,Object Para)
{
return sqlSession.selectOne(method, Para);
} public List<Map<String, String>> SelectList(String method,Object Para)
{
return sqlSession.selectList(method, Para);
} public List<Map<String, String>> SelectProc(String method,Object Para)
{
return sqlSession.selectList(method, Para);
} public void insert(String method,Object Para)
{
if(Para.getClass().getName().equals("java.util.ArrayList"))
{
ArrayList list = (ArrayList) Para;
for (int i = 0; i < list.size(); i++) {
HashMap hm = (HashMap) list.get(i);
sqlSession.insert(method, hm);
}
}
else
{
sqlSession.insert(method, Para);
}
} public void update(String method,Object Para)
{
if(Para.getClass().getName().equals("java.util.ArrayList"))
{
ArrayList list = (ArrayList) Para;
for (int i = 0; i < list.size(); i++) {
HashMap hm = (HashMap) list.get(i);
sqlSession.update(method, hm);
}
}
else
{
sqlSession.update(method, Para);
} } public void delete(String method,Object Para)
{
if(Para.getClass().getName().equals("java.util.ArrayList"))
{
ArrayList list = (ArrayList) Para;
for (int i = 0; i < list.size(); i++) {
HashMap hm = (HashMap) list.get(i);
sqlSession.delete(method, hm);
}
}
else
{
sqlSession.delete(method, Para);
}
}

路由中转操作

 public  Object doProess(String BsCode,String Operation, Object Para) {
String method=BsCode.trim()+"."+Operation.trim();
// try {
switch (Operation) {
case "SelectOne":
return SelectOne(method, Para);
case "SelectList":
return SelectList(method, Para);
case "SelectProc":
return SelectProc(method, Para);
case "insert":
insert(method, Para);
return 1;
case "update":
update(method, Para);
return 1;
case "delete":
delete(method, Para);
return 1;
default:
return "无相关操作类型"; }
// }catch (Exception e)
// {
// return e.getMessage();
// }
}

数据验证测试

 @RunWith(SpringJUnit4ClassRunner.class)  //使用junit4进行测试
@ContextConfiguration({"classpath:spring-base.xml"})
public class commServiceImplTest { @Autowired
private commService commservice; @Test
public void selectOne() throws Exception {
String bsCode="sysUserMapper";
String Operation="SelectOne";
Map<String, String> para=new HashMap<String, String>();
para.put("id","fjx");
Map<String, String> userinfo=(Map<String, String>) commservice.doProess(bsCode,Operation, para);
System.out.print(userinfo);
} @Test
public void doProess2() throws Exception {
String bsCode="sysUserMapper";
String Operation="SelectProc";
Map<String, String> para=new HashMap<String, String>();
para.put("id","fjx");
Object userinfo=commservice.doProess(bsCode,Operation,para);
System.out.print(userinfo);
} @Test
public void doProess3() throws Exception {
String bsCode="sysUserMapper";
String Operation="SelectList";
Map<String, String> para=new HashMap<String, String>();
para.put("male_","1");
Object users=commservice.doProess(bsCode,Operation,para);
System.out.print(users);
} }

GITHUB

github : https://github.com/nbfujx/Goku.WebService.Bus

Mybatis基于SqlSession实现CRUD的更多相关文章

  1. Mybatis基于代理Dao实现CRUD操作 及 Mybatis的参数深入

    Mybatis基于代理Dao实现CRUD操作 使用要求: 1.持久层接口和持久层接口的映射配置必须在相同的包下 2.持久层映射配置中mapper标签的namespace属性取值必须是持久层接口的全限定 ...

  2. SSM框架之Mybatis(2)CRUD操作

    Mybatis(2)CRUD 1.基于代理Dao实现CRUD操作 使用要求: 1.持久层接口(src\main\java\dao\IUserDao.java)和持久层接口的映射配置(src\main\ ...

  3. mybatis升级案例之CRUD操作

    mybatis升级案例之CRUD操作 一.准备工作 1.新建maven工程,和入门案例一样 主要步骤如下,可参考mybatis入门实例 a.配置pom.xml文件 b.新建实例类User.DAO接口类 ...

  4. Mybatis实现简单的CRUD(增删改查)原理及实例分析

    Mybatis实现简单的CRUD(增删改查) 用到的数据库: CREATE DATABASE `mybatis`; USE `mybatis`; DROP TABLE IF EXISTS `user` ...

  5. MyBatis学习(三)MyBatis基于动态代理方式的增删改查

    1.前言 上一期讲到MyBatis-Statement版本的增删改查.可以发现.这种代码写下来冗余的地方特别多.写一套没啥.如果涉及到多表多查询的时候就容易出现问题.故.官方推荐了一种方法.即MyBa ...

  6. 【mybatis xml】数据层框架应用--Mybatis 基于XML映射文件实现数据的CRUD

    使用MyBatis框架进行持久层开发 MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架. MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索. MyBa ...

  7. SpringMVC4+MyBatis+SQL Server2014 基于SqlSession实现读写分离(也可以实现主从分离)

    前言 上篇文章我觉的使用拦截器虽然方便快捷,但是在使用读串还是写串上你无法控制,我更希望我们像jdbc那样可以手动控制我使用读写串,那么这篇则在sqlsession的基础上实现读写分离, 这种方式则需 ...

  8. mybatis与spring的整合(使用sqlSession进行crud)

    上次介绍了用接口的方法极大的节省了dao层,只需通过 配置文件和接口就可以实现,这次介绍的是通过splsession来实现dao,这种方法比较灵活: 先不说,上配置文件: 1.web.xml < ...

  9. Hello Mybatis 01 第一个CRUD

    What's the Mybatis? MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google c ...

随机推荐

  1. 报错——userdel: user hhh is currently used by process 9218

    报错 userdel: user hhh is currently used by process 9218 [root@centos71 ~]# useradd hhh [root@centos71 ...

  2. oracle集合的应用

    union:求并集,公共部分只包含一个 ABC 和AB都没有显示出来 2:union all 相同的数据会包含两个 3:交集 intersect 既包含A又包含B 4:求差集  A集合中的数据B集合中 ...

  3. Invalid bound statement (not found)错误

    都对着,为什么会报这个错呢,mapper也拿到了,为什么查询时出错呢,最后看target里编译的文件发现少了mapping,xml没编译过去. 我的目录结构:dao层都编译过去了,但mapper.xm ...

  4. flutter图片组件

    在flutter中,image组件有很多构造函数,常用的包括Image.asset(本地图片)和Image.network(远程图片). 常用属性 不管是显示本地图片还是远程图片,image组件都包含 ...

  5. [杂题]:group(状压DP+轮廓线)

    题目描述 $pure$在玩一个战略类游戏.现在有一个士兵方阵,每行有若干士兵,每个士兵属于某个兵种.行的顺序不可改变,且每一行中士兵的顺序也不可改变.但由于每一行都有$C$个位置($C$不小于任一行的 ...

  6. MySQL清除表数据而保留表结构TRUNCATE TABLE

    有时候我们会需要清除一个表格中的所有资料.要达到者个目的,一种方式是使用 DROP TABLE 指令,不过这样整个表格就消失,表无法再被用了.另一种方式就是运用 TRUNCATE TABLE 的指令. ...

  7. Python做简单的字符串匹配详解

    Python做简单的字符串匹配详解 由于需要在半结构化的文本数据中提取一些特定格式的字段.数据辅助挖掘分析工作,以往都是使用Matlab工具进行结构化数据处理的建模,matlab擅长矩阵处理.结构化数 ...

  8. 关于vsftp出现Restarting vsftpd (via systemctl): Job for vsftpd.service failed because the control 的解决办法

    转载于:http://blog.csdn.net/it_dream_er/article/details/50783111 刚刚在搭建ftp服务器时,在配置好一切的参数之后,在我重启时,出现了无法启动 ...

  9. [BOI 2008]Elect 选举

    题目描述 N个政党要组成一个联合内阁,每个党都有自己的席位数. 现在希望你找出一种方案,你选中的党的席位数要大于总数的一半,并且联合内阁的席位数越多越好. 对于一个联合内阁,如果某个政党退出后,其它党 ...

  10. QC OTA

    Note: First make sure QTP connect to QC.(转自:http://blog.csdn.net/franktan2010/article/details/724331 ...