springMVC+mybatis 之借助SqlSessionTemplate 实现Dao层通用写法

springMVC+mybatis 之借助SqlSessionTemplate 实现Dao层通用写法在springMVC+mybatis框架开发时,通常我们会写多的dao,如userDao,roleDao,departDao等等,这样开发效果就很慢,不是很好,所以编写个通用dao.1.编写dao接口[java]viewplaincopypublicinterfaceDAO{/***保存对象*@paramstr*@paramobj*@retu…

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

在springMVC+mybatis框架开发时,通常我们会写多的dao,如userDao,roleDao,departDao等等,这样开发效果就很慢,不是很好,所以编写个通用dao.

SqlSessionTemplate是MyBatis-Spring的核心。这个类负责管理MyBatis的SqlSession,调用MyBatis的SQL方法,翻译异常。SqlSessionTemplate是线程安全的,可以被多个DAO所共享使用。

当调用SQL方法时,包含从映射器getMapper()方法返回的方法,SqlSessionTemplate将会保证使用的SqlSession是和当前Spring的事务相关的。此外,它管理session的生命周期,包含必要的关闭,提交或回滚操作。

SqlSessionTemplate实现了SqlSession,这就是说要对MyBatis的SqlSession进行简易替换。

SqlSessionTemplate通常是被用来替代默认的MyBatis实现的DefaultSqlSession,因为它不能参与到Spring的事务中也不能被注入,因为它是线程不安全的。相同应用程序中两个类之间的转换可能会引起数据一致性的问题。

SqlSessionTemplate对象可以使用SqlSessionFactory作为构造方法的参数来创建。
例如:

<!-- 创建sqlSessionFactoryBean -->
 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean" p:dataSource-ref="dataSource" p:configLocation="classpath:mybatis-config.xml" p:mapperLocations="classpath:com/mf/*/entity/mapper/*.xml" p:plugins-ref="pagePlugin" />

 <!-- 配置sqlSessionTemplate -->
 <bean class="org.mybatis.spring.SqlSessionTemplate">
  <constructor-arg ref="sqlSessionFactory" />
 </bean>

编写步骤:

1.编写dao接口

public interface DAO { 
     
      
    /** * 保存对象 * @param str * @param obj * @return * @throws Exception */  
    public Object save(String str, Object obj) throws Exception;  
      
    /** * 修改对象 * @param str * @param obj * @return * @throws Exception */  
    public Object update(String str, Object obj) throws Exception;  
      
    /** * 删除对象 * @param str * @param obj * @return * @throws Exception */  
    public Object delete(String str, Object obj) throws Exception;  
  
    /** * 查找对象 * @param str * @param obj * @return * @throws Exception */  
    public Object findForObject(String str, Object obj) throws Exception;  
  
    /** * 查找对象 * @param str * @param obj * @return * @throws Exception */  
    public Object findForList(String str, Object obj) throws Exception;  
      
    /** * 查找对象封装成Map * @param s * @param obj * @return * @throws Exception */  
    public Object findForMap(String sql, Object obj, String key , String value) throws Exception;  
      
}  

2.编写dao 实现类

public class DaoSupport implements DAO { 
     
  
    @Resource(name = "sqlSessionTemplate")  
    private SqlSessionTemplate sqlSessionTemplate;  
      
    /** * 保存对象 * @param str * @param obj * @return * @throws Exception */  
    public Object save(String str, Object obj) throws Exception { 
     
        return sqlSessionTemplate.insert(str, obj);  
    }  
      
    /** * 批量更新 * @param str * @param obj * @return * @throws Exception */  
    public Object batchSave(String str, List objs )throws Exception{ 
     
        return sqlSessionTemplate.insert(str, objs);  
    }  
      
    /** * 修改对象 * @param str * @param obj * @return * @throws Exception */  
    public Object update(String str, Object obj) throws Exception { 
     
        return sqlSessionTemplate.update(str, obj);  
    }  
  
    /** * 批量更新 * @param str * @param obj * @return * @throws Exception */  
    public void batchUpdate(String str, List objs )throws Exception{ 
     
        SqlSessionFactory sqlSessionFactory = sqlSessionTemplate.getSqlSessionFactory();  
        //批量执行器 
        SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH,false);  
        try{ 
     
            if(objs!=null){ 
     
                for(int i=0,size=objs.size();i<size;i++){ 
     
                    sqlSession.update(str, objs.get(i));  
                }  
                sqlSession.flushStatements();  
                sqlSession.commit();  
                sqlSession.clearCache();  
            }  
        }finally{ 
     
            sqlSession.close();  
        }  
    }  
      
    /** * 批量更新 * @param str * @param obj * @return * @throws Exception */  
    public Object batchDelete(String str, List objs )throws Exception{ 
     
        return sqlSessionTemplate.delete(str, objs);  
    }  
      
    /** * 删除对象 * @param str * @param obj * @return * @throws Exception */  
    public Object delete(String str, Object obj) throws Exception { 
     
        return sqlSessionTemplate.delete(str, obj);  
    }  
       
    /** * 查找对象 * @param str * @param obj * @return * @throws Exception */  
    public Object findForObject(String str, Object obj) throws Exception { 
     
        return sqlSessionTemplate.selectOne(str, obj);  
    }  
  
    /** * 查找对象 * @param str * @param obj * @return * @throws Exception */  
    public Object findForList(String str, Object obj) throws Exception { 
     
        return sqlSessionTemplate.selectList(str, obj);  
    }  
      
    public Object findForMap(String str, Object obj, String key, String value) throws Exception { 
     
        return sqlSessionTemplate.selectMap(str, obj, key);  
    }  
      
}  

3.那么怎么使用呢?

public class UserService { 
     
  
    @Resource(name = "daoSupport")  
    private DaoSupport dao;  
  
    /* *通过id获取数据 */  
    public User getUserAndRoleById(String userid) throws Exception { 
     
        return (User) dao.findForObject("UserMapper.getUserAndRoleById", <span style="font-family: Arial, Helvetica, sans-serif;">userid</span>);  
    }   
}  

4. UserMapper.xml中的配置

<?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="UserMapper">  
<select id="getUserById" parameterType="String" resultType="User">  
    select  * from SYS_USER where userId=#{userId}  
</select>  
lt;/mapper>  

namespqce:是随意起的 不是规定必须叫 userNamespace

5.mybatis配置文件

<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE mapper PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">  
<mapper namespace="Test">  
  
    <select id="queryDataCount" parameterType="com.mybatis.Test" resultType="int">  
        SELECT COUNT(1) FROM INF_CONSUMER T WHERE T.UUID = #{uuid}  
    </select>  
      
</mapper>  

6.具体DAO配置

package com.dwr;  
  
import org.springframework.stereotype.Repository;  
  
import com.mybatis.Test;  
  
@Repository  
public class TestDAO extends MyBatisDAO { 
     
  
    public int getCount(Test test) { 
     
        return (Integer) this.getObject("Test.queryDataCount", test);  
    }  
}  

这样一个通用的Dao解决了。

转载:https://blog.csdn.net/hellolovelife/article/details/78476099

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

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

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


相关推荐

  • 将java或javaweb项目打包为jar包或war包[通俗易懂]

    将java或javaweb项目打包为jar包或war包[通俗易懂]一、为什么打包?         关于此问题,网上众说纷纭。结合个人理解以及网上说法,打成jar包,方便别人使用。如果别人运行java程序,不需要在寻找包含main方法的类去执行;如果别人使用jar包,直接在自己项目中导入jar包,而不是赋值一堆类文件。打成war包是真实生产化境,选择的web应用部署方式,网上说…

    2022年5月10日
    56
  • 西班牙语语法【2 : 动词】

    西班牙语语法【2 : 动词】时态时态描述陈述式_现在时陈述式_简单过去时陈述式_过去未完成时陈述式_将来未完成时陈述式_过去完成时陈述式_现在完成时陈述式_将来完成时虚拟式_现在时虚拟式_过去时条件式_过去将来时过去将来完成时…

    2022年6月10日
    32
  • java实现第八届蓝桥杯数位和

    java实现第八届蓝桥杯数位和数位和题目描述数学家高斯很小的时候就天分过人。一次老师指定的算数题目是:1+2+…+100。高斯立即做出答案:5050!这次你的任务是类似的。但并非是把一个个的数字加起来,而是对该数字的每一个数位作累加。这样从1加到100的“和”是:901从10加到15是:21,也就是:1+0+1+1+1+2+1+3+1+4+1+5,这个口算都可以出结果的。按这样的“加法”,从1加到1000是…

    2022年6月15日
    39
  • [USACO12JAN]视频游戏的连击Video Game Combos「建议收藏」

    很早之前就做过啦补一下题解F(i,j)前i个的字符为j的匹配注意end要累加#include&lt;iostream&gt;#include&lt;cstdio&gt;#include&lt;cstring&gt;#include&lt;cmath&gt;#include&lt;algorithm&gt;#include&lt;queue&gt;usingnam…

    2022年4月10日
    46
  • linux重启网卡的命令行,linux系统怎么重启网卡?linux重启网卡的三种教程

    linux重启网卡的命令行,linux系统怎么重启网卡?linux重启网卡的三种教程在实际工作中,经常会遇到Linux系统进行重启网卡的操作。在这里整理一下,进行多种方法的网卡重启。一、servicenetworkrestart1、首先用CRT工具连接到Linux命令行界面。或者进入操作系统界面,选择终端输入。2、如果我们对所有的网卡进行重启操作。可以尝试输入:servicenetworkrestart命令进行操作。3、样就完成了用servicenetworkr…

    2022年9月22日
    4
  • 圆柱体体积的计算公式圆柱体积的计算公式_空心圆柱重量计算公式

    圆柱体体积的计算公式圆柱体积的计算公式_空心圆柱重量计算公式圆柱的体积计算公式同仁实验学校各年级组备课教师教案教案设计课题教学内容年级六年级科目圆柱体积的计算公式数学教案类型新授P25页例5及补充例题,完成“做一做”及练习五第1~3题。授课人1、通过用切割拼合的方法借助长方体的体积公式推导出圆柱的体积公式,能够运用公教学目标式正确地计算圆柱的体积和容积。2、初步学会用转化的数学思想和方法,解决实际问题的能力。3、渗透转化思想,培养…

    2026年1月30日
    4

发表回复

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

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