mybatis spring配置SqlSessionTemplate使用

本文详细介绍如何在Spring框架中整合MyBatis,包括application.xml配置、MyBatisDAO实现及具体的DAO配置等核心内容。文章还展示了如何通过Spring管理数据源及MyBatis会话工厂,并提供了一个具体的数据访问对象示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[size=large][color=red]1.application.xml配置[/color][/size]


<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:dwr="http://www.directwebremoting.org/schema/spring-dwr"
xmlns:lang="http://www.springframework.org/schema/lang"
xmlns:top="http://www.comtop.org/schema/spring-top"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd
http://www.directwebremoting.org/schema/spring-dwr
http://www.directwebremoting.org/schema/spring-dwr-3.0.xsd
http://www.springframework.org/schema/lang
http://www.springframework.org/schema/lang/spring-lang-3.2.xsd
http://www.comtop.org/schema/spring-top
http://www.comtop.org/schema/top/spring-top.xsd">

<!-- spring 注解 -->
<context:component-scan base-package="com.dwr"/>

<!-- 这句的作用是表示允许DWR访问Spring的Context -->
<dwr:annotation-config id="dwr_as"/>
<!-- 扫描加了注解@RemoteProxy & @RemoteMethod 的对象 -->
<dwr:annotation-scan scanRemoteProxy="false" base-package="com.dwr" />
<!-- dwr初始化配置 -->
<dwr:configuration></dwr:configuration>

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@10.10.15.29:1521:xxxx" />
<property name="username" value="edmp" />
<property name="password" value="edmp" />
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath:com/mybatis/*.xml" />
</bean>
<bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>

<import resource="RESTful.xml" />

</beans>


[color=red][size=large]2.MyBatisDAO :[/size][/color]

package com.dwr;

import java.util.List;

import javax.annotation.Resource;

import org.apache.ibatis.session.RowBounds;
import org.mybatis.spring.SqlSessionTemplate;
import org.springframework.stereotype.Repository;

@Repository
public class MyBatisDAO{

@Resource
private SqlSessionTemplate sqlSessionTemplate;

public MyBatisDAO() {
}

public void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate) {
this.sqlSessionTemplate = sqlSessionTemplate;
}

public void delete(String statementId, Object deleteObject) {
try {
this.sqlSessionTemplate.delete(statementId, deleteObject);
} catch (Exception e) {
}
}

public void insert(String statementId, Object insertObject) {
try {
this.sqlSessionTemplate.insert(statementId, insertObject);
} catch (Exception e) {
}
}


public void update(String statementId, Object updateObject) {
try {
this.sqlSessionTemplate.update(statementId, updateObject);
} catch (Exception e) {
}
}


public Object getObject(String statementId, Object selectParamObject) {
return this.sqlSessionTemplate
.selectOne(statementId, selectParamObject);
}

@SuppressWarnings("all")
public List queryList(String statementId, Object queryParamObject) {
return this.sqlSessionTemplate
.selectList(statementId, queryParamObject);
}
@SuppressWarnings("all")
public List queryList(String statementId, Object queryParamObject,
int pageNo, int pageSize) {
RowBounds objRowBounds;
int iOffset = (pageNo - 1) * pageSize;
objRowBounds = new RowBounds(iOffset, pageSize);
return this.sqlSessionTemplate.selectList(statementId,
queryParamObject, objRowBounds);
}
}



[size=large][color=red]3.mybatis配置文件[/color][/size]


<?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>



[size=large][color=red]4.具体DAO配置[/color][/size]


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);
}
}

### 配置与最佳实践 #### 使用 `SqlSessionTemplate` 整合 MyBatisSpring配置实例 为了使 MyBatis 能够无缝集成到基于 Spring 的应用程序中,推荐使用 `SqlSessionTemplate` 来管理数据库会话。这种方式不仅简化了事务处理逻辑,还提供了更好的性能优化。 ```xml <!-- applicationContext.xml --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> </bean> <bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate"> <constructor-arg index="0" ref="sqlSessionFactory"/> </bean> ``` 通过上述 XML 片段可以创建一个名为 `sqlSessionTemplate` 的 Bean 实例[^2]。此实例将在整个应用上下文中共享同一个 SessionFactory,从而减少了资源消耗并提高了效率。 对于 DAO 层的设计,则可以通过依赖注入的方式引入已经定义好的 `SqlSessionTemplate` 对象: ```java public class UserDaoImpl implements UserMapper { private SqlSession sqlSession; public void setSqlSession(SqlSession sqlSession){ this.sqlSession = sqlSession; } @Override public List<User> getAllUsers() { return sqlSession.selectList("User.selectAll"); } } ``` 在此代码片段中展示了如何利用 setter 方法来设置 `sqlSession` 属性值,并实现接口中的查询操作。需要注意的是,在实际项目开发过程中应当遵循面向接口编程的原则,即让具体的 Dao 类去实现相应的 Mapper 接口而不是直接调用底层 API 函数。 #### 最佳实践建议 当采用 `SqlSessionTemplate` 进行数据访问层设计时,应考虑以下几个方面以确保系统的稳定性和可维护性: - **统一异常转换**: 将所有来自 JDBC 或者 MyBatis 抛出的运行期异常封装成自定义业务异常类型; - **合理运用缓存机制**: 根据具体需求开启或关闭一级/二级缓存功能; - **保持良好的分页支持**: 如果涉及到大量记录读取场景下务必提供有效的分页解决方案; - **充分利用 AOP 切面技术**: 可以为所有的 dao 操作添加日志记录、权限验证等功能模块而不必修改原有代码结构。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值