• Ibatis中SqlMapClientTemplate和SqlMapClient的区别


    SqlMapClientTemplate是org.springframework.orm.ibatis下的

    而SqlMapClient是ibatis的

    SqlMapClientTemplate是SqlMapClient的封装类. 
    SqlMapClient中包含着session的管理. 
    SqlMapClientTemplate用于session的封装,以及异常的捕捉. 
    所以按照以上的推断来说.应该尽量使用SqlMapClientTemplate. 
    保证session以及Exception的正常以及统一.

    下面是两种类型在spring中的集成配置及用法:、

    SqlMapClientTemplate:

    1、在spring中的配置

    1. <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
    2. <property name="dataSource" ref="dataSource" />
    3. <property name="configLocation">
    4. <value>classpath:/sqlmap-config.xml</value>
    5. </property>
    6. </bean>
    7. <bean id="sqlMapClientTemplate" class="org.springframework.orm.ibatis.SqlMapClientTemplate">
    8. <property name="sqlMapClient" ref="sqlMapClient"></property>
    9. </bean>
    10. <bean id="accountDAO" class="com.raycloud.test.dao.AccountDAO">
    11. <property name="sqlMapClientTemplate" ref="sqlMapClientTemplate"></property>
    12. </bean>

    2、在dao中的实现

    1. @Repository//使用该注解相当于声明了一个bean
    2. public class AccountDAO {
    3. SqlMapClientTemplate sqlMapClientTemplate;
    4. public void setSqlMapClientTemplate(SqlMapClientTemplate sqlMapClientTemplate) {
    5. this.sqlMapClientTemplate = sqlMapClientTemplate;
    6. }
    7. public Integer addAccount(Account account) throws SQLException{
    8. return (Integer)this.sqlMapClientTemplate.insert("Account.insertAccount", account);
    9. }
    10. }

    SqlMapClient:
    1、在spring中的配置

    1. <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
    2. <property name="dataSource" ref="dataSource" />
    3. <property name="configLocation">
    4. <value>classpath:/sqlmap-config.xml</value>
    5. </property>
    6. </bean>
    7. <bean id="accountDAO" class="com.raycloud.test.dao.AccountDAO">
    8. <property name="sqlMapClient" ref="sqlMapClient"></property>
    9. </bean>

    2、在dao中的实现

    1. @Repository//使用该注解相当于声明了一个bean
    2. public class AccountDAO {
    3. SqlMapClient sqlMapClient;
    4. public void setSqlMapClient(SqlMapClient sqlMapClient) {
    5. this.sqlMapClient = sqlMapClient;
    6. }
    7. public Integer addAccount(Account account) throws SQLException{
    8. return (Integer)this.sqlMapClient.insert("Account.insertAccount", account);
    9. }
    10. }
  • 相关阅读:
    数据库性能优化之冗余字段的作用
    SQL里面的排序语句desc和ASC有什么区别
    Mybatis@options注解属性useGeneratedKeys,keyProperty,keyColumn的使用
    关于resultType与parameterType的基本使用和区别
    阿里云Centos7的部署springboot后mysql中文问号乱码
    LINUX下启动/停止/重启MYSQL
    CondenseNet:可学习分组卷积,原作对DenseNet的轻量化改造 | CVPR 2018
    MnasNet:经典轻量级神经网络搜索方法 | CVPR 2019
    MobileNetV1/V2/V3简述 | 轻量级网络
    ShuffleNetV1/V2简述 | 轻量级网络
  • 原文地址:https://www.cnblogs.com/edda/p/12745220.html
Copyright © 2020-2023  润新知