博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mybatis之sqlSession无需开发人员close
阅读量:5062 次
发布时间:2019-06-12

本文共 1109 字,大约阅读时间需要 3 分钟。

根据mybatis官方文档,建议对sqlSession进行如下操作

 

SqlSession session = sqlSessionFactory.openSession();try{
// following 3 lines pseudocod for "doing some work" session.insert(...); session.update(...); session.delete(...); session.commit();}finally{
session.close();}

每个操作都进行打开和关闭,而且都是重复性操作。

 

于是mybatis-3.0.6采用动态代理实现的aop非常好的解决了上面的问题。

大体实现方式如下:

1.在applicationContext.xml中配置

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">

        <property name="configLocation">
            <value>classpath:mybatisConfig.xml</value>
        </property>
        <property name="dataSource">
            <ref bean="dataSource" />
        </property>
    </bean>
    <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
        <constructor-arg index="0" ref="sqlSessionFactory" />
    </bean>

2.在具体的使用类中执行如下操作,即可。

int identifier = sqlSession.insert(statement, object);

大体原理:

执行sqlSession.insert及执行SqlSessionTemplate.insert,其内部调用sqlSessionProxy.insert,sqlSessionProxy是一个动态代理器,其调用处理器是SqlSessionInterceptor,该处理器先getSqlSession,然后执行insert,最后closeSqlSession。

不明白的同学可直接查看mybatis-3.0.6源码

转载于:https://www.cnblogs.com/langtianya/archive/2013/03/04/2942938.html

你可能感兴趣的文章
【AppScan心得】IBM Rational AppScan 无法记录登录序列
查看>>
[翻译] USING GIT IN XCODE [4] 在XCODE中使用GIT[4]
查看>>
简化通知中心的使用
查看>>
SpringMVC的@Validated校验注解使用方法
查看>>
Python之os模块
查看>>
IO—》Properties类&序列化流与反序列化流
查看>>
【蓝桥杯】PREV-21 回文数字
查看>>
html 简介
查看>>
python使用上下文对代码片段进行计时,非装饰器
查看>>
js中比较实用的函数用法
查看>>
安装预览版镜像后无法检测到预览版更新的解决方案
查看>>
【bzoj5099】[POI2018]Pionek 双指针法
查看>>
别让安全问题拖慢了 DevOps!
查看>>
JAR打包和运行
查看>>
session如何保存在专门的StateServer服务器中
查看>>
react展示数据
查看>>
测试计划
查看>>
idea设置自定义图片
查看>>
[高级]Android多线程任务优化1:探讨AsyncTask的缺陷
查看>>
选择器
查看>>