SpringMVC与Mybatis整合简介

  Spring 与 Mybatis 的整合相对成熟,网上许多demo可供参考。一般推荐使用maven管理jar包,下面罗列整合所需jar包

<!-- MySQL+Mybatis:mybatis、mybatis-spring、spring-jdbc、druid、mysql-connector-java、pagehelper -->

     <!-- mybatis基础包 -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.3.0</version>
        </dependency>
     <!-- mybatis与spring整合中间包 -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>1.2.3</version>
        </dependency>
     <!-- spring整合jdbc的驱动包 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>        
            <version>${spring.version}</version>
        </dependency>
     <!-- druid连接池,还有c3p0 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.0.18</version>
        </dependency>
     <!-- 连接mysql数据库-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.38</version>
        </dependency>
     <!-- mybatis分页插件 -->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper</artifactId>
            <version>4.1.4</version>
        </dependency>

   在jdbc.properties中定义数据库连接属性值

### 数据库连接配置 ###

################## MySQL ##################
#db.dbType=mysql  ----- home
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://192.168.8.85:3306/basic?useUnicode=true&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&rewriteBatchedStatements=true
jdbc.username=root
jdbc.password=root

 

<?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"
       xsi:schemaLocation="http://www.springframework.org/schema/beans 
                              http://www.springframework.org/schema/beans/spring-beans.xsd
                              http://www.springframework.org/schema/aop 
                              http://www.springframework.org/schema/aop/spring-aop.xsd
                           http://www.springframework.org/schema/tx 
                           http://www.springframework.org/schema/tx/spring-tx.xsd
                           http://www.springframework.org/schema/context 
                           http://www.springframework.org/schema/context/spring-context.xsd">

    <!-- 基于Druid数据库链接池的数据源配置 -->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
        <!-- 基本属性driverClassName、 url、user、password -->
        <property name="driverClassName" value="${jdbc.driver}" />
        <property name="url" value="${jdbc.url}" />
        <property name="username" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
        <!-- 配置初始化大小、最小、最大 -->
        <!-- 通常来说,只需要修改initialSize、minIdle、maxActive -->
        <property name="initialSize" value="2" />
        <property name="minIdle" value="2" />
        <property name="maxActive" value="30" />
        <property name="testWhileIdle" value="false" />

        <!-- 配置获取连接等待超时的时间 -->
        <property name="maxWait" value="5000" />
        <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
        <property name="minEvictableIdleTimeMillis" value="30000" />
        <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
        <property name="timeBetweenEvictionRunsMillis" value="60000" />
        <!-- 解密密码必须要配置的项 -->
        <property name="filters" value="config" />
        <property name="connectionProperties" value="config.decrypt=false" />
    </bean>
    
    <!-- SqlSession模板类实例 -->
    <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate" scope="prototype" destroy-method="close">
        <constructor-arg index="0" ref="sqlSessionFactory" />
    </bean>
    <!-- 将数据源映射到sqlSessionFactory中 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="configLocation" value="classpath:mybatis/mybatis-config.xml" />
        <property name="dataSource" ref="dataSource" />
        <property name="plugins">
            <array>
                   <bean class="com.github.pagehelper.PageHelper">
                       <property name="properties">
                           <value>
                               dialect=hsqldb
                           </value>
                       </property>
                   </bean>
            </array>
        </property>
    </bean>
    
    <!--======= 事务配置 Begin ================= -->
    <!-- 事务管理器(由Spring管理MyBatis的事务) -->
    <!-- <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        关联数据源
        <property name="dataSource" ref="dataSource"></property>
    </bean> -->
    
    <!-- <tx:annotation-driven transaction-manager="transactionManager" /> -->
    <!--======= 事务配置 End =================== -->


</beans>

 

  定义mybatis-config.xml :配置Mapper的访问路径,给对象定义别名

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!-- 定义mybatis运行时的行为方式 -->
    <settings>
        <!-- 这个配置使全局的映射器启用或禁用 缓存 -->
        <setting name="cacheEnabled" value="true" />
        <!-- 全局启用或禁用延迟加载。当禁用时, 所有关联对象都会即时加载 -->
        <setting name="lazyLoadingEnabled" value="true" />
        <!-- 允许或不允许多种结果集从一个单独 的语句中返回(需要适合的驱动) -->
        <setting name="multipleResultSetsEnabled" value="true" />
        <!-- 使用列标签代替列名。 不同的驱动在这 方便表现不同。 参考驱动文档或充分测 试两种方法来决定所使用的驱动 -->
        <setting name="useColumnLabel" value="true" />
        <!-- 允许 JDBC 支持生成的键。 需要适合的 驱动。 如果设置为 true 则这个设置强制 生成的键被使用, 尽管一些驱动拒绝兼 容但仍然有效(比如Derby) -->
        <setting name="useGeneratedKeys" value="false" />
        <!-- 配置默认的执行器。SIMPLE 执行器没 有什么特别之处。REUSE 执行器重用 预处理语句。BATCH 执行器重用语句 和批量更新 -->
        <setting name="defaultExecutorType" value="SIMPLE" />
        <!-- 设置超时时间, 它决定驱动等待一个数 据库响应的时间 -->
        <setting name="defaultStatementTimeout" value="100" />
        <setting name="safeRowBoundsEnabled" value="false" />
        <setting name="mapUnderscoreToCamelCase" value="false" />
        <setting name="localCacheScope" value="SESSION" />
        <setting name="jdbcTypeForNull" value="OTHER" />
        <setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode,toString" />
    </settings>

    <!-- 类型别名是为 Java类型命名一个短的名字,方便在核心配置、映射配置中来使用这个java类型。 它只和 XML配置有关,只用来减少类完全 限定名的多余部分 -->
    <typeAliases>
        <!-- system -->
        <typeAlias type="com.model.system.SystemArea" alias="SystemArea" />
        <!-- <typeAlias type="com.model.system.SystemConstant" alias="SystemConstant" />
        <typeAlias type="com.model.system.SystemFiles" alias="SystemFiles" />
        <typeAlias type="com.model.system.User" alias="User" />
        <typeAlias type="com.model.system.UserAction" alias="UserAction" />
        <typeAlias type="com.model.system.UserMenu" alias="UserMenu" />
        <typeAlias type="com.model.system.UserRole" alias="UserRole" />
        <typeAlias type="com.model.system.UserRoleAction" alias="UserRoleAction" />
        <typeAlias type="com.model.system.UserRoleMenu" alias="UserRoleMenu" /> -->
    </typeAliases>

    <!-- 放在mappers定义之前,将获取的值以合适的方式转换成Java类型 -->
    <typeHandlers>
        <!-- <typeHandler javaType="Boolean" jdbcType="SMALLINT" handler="com.guduo.common.core.mybatis.BooleanTypeHandler" /> -->
    </typeHandlers>
    
    <!-- Mapper映射器, 定义扫描的Mapper地址,不扫描会报错 -->
    <mappers>
        
        <!-- system -->
        <mapper resource="mybatis/mappers/system/SystemAreaMapper.xml" />
        <!-- <mapper resource="mybatis/mappers/system/SystemConstantMapper.xml" />
        <mapper resource="mybatis/mappers/system/SystemFilesMapper.xml" /> --> 
        
        <!-- 两种定义方式:一种每个mapper定义一种;一种是定义mapper包路径 -->
        <!-- <mapper resource="com/yu/res/UserMapper.xml" /> -->
         
        <!-- 推荐使用 -->
        <!-- <package name="com.yu.mapper"/> -->
    </mappers>

</configuration>