Spring整合Mybatis
一切随缘~~~ 人气:0Spring整合Myabtis思路的分析
引入相关依赖
Spring
Myabtis
mysql
Mybatsi-spring
…
如何整合?
Spring:
项目管理框架,主要是用来负责项目中组件对象的创建,使用,销毁。
Mybatis:
持久层框架,主要是用来简化原始jdbc技术对数据库访问操作。
== >整合思路:通过Spring框架接管Mybatis框架中核心对象的创建。
Mybatis框架中核心对象是谁?
- sqlSession?
- SqlSessionFactory?
- SqlSessionFactoryBuilder?
- dao?
最核心的对象必然是: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/>
加载全部内容