java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Spring整合Mybatis

Spring整合Mybatis思路梳理总结

作者:一切随缘~~~

MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作,本篇文章带你了解Spring整合Mybatis的思路

Spring整合Myabtis思路的分析

引入相关依赖

Spring

Myabtis

mysql

Mybatsi-spring

如何整合?

Spring:

项目管理框架,主要是用来负责项目中组件对象的创建,使用,销毁。

Mybatis:

持久层框架,主要是用来简化原始jdbc技术对数据库访问操作。

== >整合思路:通过Spring框架接管Mybatis框架中核心对象的创建。

Mybatis框架中核心对象是谁?

最核心的对象必然是:SqlSessionFactory。

SqlSessionFactoryBuilder的作用就是读取解析配置文件==【数据源配置,mapper文件配置】==,来创建SqlSessionFactory。

SqlSession的创建又依靠于SqlSessionFactory。

== > SqlSessionFactory是最核心的对象。

SM整合

整合思路:通过Spring框架接管Mybatis中核心的SqlSessionFactory对象的创建。

SqlSessionFactory是简单对象还是复杂对象呢?

如果是简单对象

<bean id="" class=""/>

如果是复杂对象

通过查看源码得知,SqlSessionFactory是一个接口类型的复杂对象。

如何创建?

is = Resources.getResourceAsStream("mybatis-config.xml");
sqlSessionFactory = new SqlSessionFactoryBuilder(),build(is);
1).SqlSessionFactory(Factory)Bean implements FactoryBean<SqlSessionFactory> {
  	SqlSessionFactory getObject() {
        is = Resources.getResourceAsStream("mybatis-config.xml");
		sqlSessionFactory = new SqlSessionFactoryBuilder(),build(is);
    }	  
    Class getClass() {
        return SqlSessionFactory.class;
    }
    boolean isSingleton() {
        return true;
    }
 }
2).工厂管理SqlSessionFactory
<bean id="sqlSessionFactory" class="xxx.SqlSessionFactoryBean">
3).工厂获取
SqlSessionFactory sf = context.getBean("sqlSessionFactory");

写完之后,我们可以发现,这段代码是固定不变的,这个项目要写,别的项目也要写。

于是Mybatis官方替我们写好了,对这段代码进行了封装:Mybatis-spring.jar。

jar包里提供了一个类:SqlSessionFactoryBean。

我们以后只要引Mybatsi-spring依赖就可以了,不用在自己去写了。

值得注意的是:mybatis官方提供SqlSessionFactoryBean,不在使用mybaits主配置文件。

主配置文件的核心就是【数据源】【mapper文件的注册】

所以我们要注入数据源对象,引入druid依赖,注入mapper文件的位置。【DI思想,依赖注入】

<!-- 配置Spring.xml文件 -->

<!-- 创建数据源对象 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" >
	<property name="driverName" value="com.mysql.cj.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/xxx"/>
    <property name="username" value="root"/>
    <property name="password" value="root"/>
<bean/>

<!-- 创建SqlSessionFactory对象 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!-- 注入数据源对象 -->
    <property name="dataSource" ref="dataSource" />
    <!-- 注入mapper文件的位置 -->
    <property name="mapperLocations">
        <array>
            <value>.....</value>
        </array>
    </property>
<bean/>

到此这篇关于Spring整合Mybatis思路梳理总结的文章就介绍到这了,更多相关Spring整合Mybatis内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文