13.Spring-整合Mybatis
本文最后更新于2023.11.30-17:58,某些文章具有时效性,若有错误或已失效,请在下方留言或联系涛哥。
正常使用mybatis:数据源 -->获取连接池-->会话工厂-->使用mapper进行 增删改查操作。
Spring整合mybatis 其实就是
1 由Spring 来统一管理 数据源:
2 由Spring 来管理 sqlsessionFactory 单例
3 使用SqlSessionFactory 去获取sqlSession (Spring整合mybatis时 自动完成)
4.持久层的 mapper 都需要由Spring 进行统一管理生成 mapper的代理对象
需要的jar包:
- spring相关jar包 容器 aop
 - spring-jdbc jar包
 - mybatis 相关的jar包
 - mybatis-spring 的jar包
 - 连接池的相关jar包 (c3p0/druid)
 - 数据连接相关的jar包
 - 其他:日志 单元测试
 
需要的文件:
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.edu</groupId>
    <artifactId>smDemo</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <!-- spring相关jar包 容器 aop
            spring-jdbc jar包
            mybatis 相关的jar包
            mybatis-spring 的jar包
            连接池的相关jar包 (c3p0 druid)
            数据连接相关的jar包(jdbc)
              其他:日志 单元测试
          -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.2.4.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>aopalliance</groupId>
            <artifactId>aopalliance</artifactId>
            <version>1.0</version>
        </dependency>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.9.6</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.2.4.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.5</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.44</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba.druid</groupId>
            <artifactId>druid-wrapper</artifactId>
            <version>0.2.9</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>2.0.6</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>RELEASE</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>
spring的配置文件: applicationContext.xml
<?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: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/context http://www.springframework.org/schema/context/spring-context.xsd">
    <context:component-scan base-package="com.rimi.*"></context:component-scan>
    <context:property-placeholder location="classpath:resource/db.properties" />
<!-- spring可开启自动扫描   -->
<!-- 首先配置数据源 c3p0和 druid 配置类似   -->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
          destroy-method="close">
        <!-- 数据库的连接url       -->
        <property name="url" value="${jdbc.url}" />
        <!--  数据库用户名       -->
        <property name="username" value="${jdbc.username}" />
        <!--  数据库密码      -->
        <property name="password" value="${jdbc.password}" />
        <!--   数据库的 驱动的 class名       -->
        <property name="driverClassName" value="${jdbc.driver}" />
        <!--   数据库的 最大连接数       -->
        <property name="maxActive" value="10" />
        <!--   最小的连接数  连接池的其他属性 请自查       -->
        <property name="minIdle" value="5" />
    </bean>
    <!--将Mybaties的会话 工厂 交由Spring 管理 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!--  设置 mybties 自身的的配置文件的路径       -->
        <property name="configLocation" value="classpath:mybatis/sqlMapConfig.xml"></property>
<!--        <!–  设置mybatis 会话工厂的 数据源       –>-->
        <property name="dataSource" ref="dataSource"></property>
    </bean>
<!--     配置 mybaits Mapper的代理的生成-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.rimi.dao"></property>
    </bean>
</beans>
mybatis的配置文件:mybatis.config.xml
<?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>
<!-- 配置别名 -->
    <typeAliases>
        <!-- 批量扫描别名 -->
        <package name="com.rimi.bean"/>
    </typeAliases>
    <!-- 配置分页插件 -->
<!--    <plugins>-->
<!--        <plugin interceptor="com.github.pagehelper.PageHelper">-->
<!--            <!– 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库–>        -->
<!--            <property name="dialect" value="mysql"/>-->
<!--        </plugin>-->
<!--    </plugins>-->
</configuration>
mybatis的映射文件 ;mybatis.mapper;
<?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="com.rimi.dao.UserMapper">
    <select id="selectUserById" parameterType="java.lang.Integer" resultType="user">
        select * from user where userid = #{id}
    </select>
</mapper>
整合案例
阅读剩余
            版权声明:
作者:涛哥
链接:https://ltbk.net/back/spring_family/spring/article/409.html
文章版权归作者所有,未经允许请勿转载。
            作者:涛哥
链接:https://ltbk.net/back/spring_family/spring/article/409.html
文章版权归作者所有,未经允许请勿转载。
        THE END
    
        
        






