亲宝软件园·资讯

展开

Spring整合Mybatis

一切随缘~~~ 人气:0

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/>

加载全部内容

相关教程
猜你喜欢
用户评论