《\mybatis\day02\16mybatis和spring整合-sqlSessionFactory配置.avi;》

MyBatis学习七:spring和MyBatis整合、逆向工程 - mwj_88的专栏 - CSDN博客--和老是讲课相同--已经拷贝在下方
http://blog.csdn.net/mwj_88/article/details/50315701

添加 source folder 这是一个虚拟目录
点击folder 就是真实目录

spring和 springMVC 和mybatis整合;
1、添加对应的jar包,
2、配置文件 在applicationContext.xml配置sqlSessionFactory和数据源
spring/applicationContext.xml
mybatis/SqlMapConfig.xml
3、有原始DAO开发 和 mapper代理开发

=======【转】MyBatis学习七:spring和MyBatis整合、逆向工程 - mwj_88的专栏 ==============

一、整合思路

需要spring通过单例方式管理SqlSessionFactory。

spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSession(spring和mybatis整合自动完成)。

持久层的mapper都需要由spring进行管理。

二、整合之后结构图

  

三、配置SqlSessionFactory和数据源

在applicationContext.xml配置SqlSessionFactory和数据源。

<!—加载配置文件 -->

<context:property-placeholder location=”classpath:db.properties”/>
<!—数据源,使用dbcp -->
<bean id=”dataSource” class=”org.apache.commons.dbcp.BasicDataSource” destroy-method=”close”>
<property name=”driverClassName” value=”${jdbc.driver}”
//继续配置url、username、password、maxActive、maxIdle等
</bean>
<!-- sqlSessionFactory -->
<bean id=”sqlSessionFactory” class=”org.mybatis.spring.SqlSessionFactoryBean”>
<!—加载mybatis的配置文件 -->
<property name=”configLocation” value=”mybatis/SqlMapConfig.xml”/>
<!—数据源 -->
<property name=”datasource” ref=” datasource”/>
</bean>

假设已经写好pojo、映射文件(原始dao方式名称为User.xml;代理开发方式为xxMapper.xml)。、在SQLConfigMap.xml中加载映射文件,然后接着开发:

四、原始dao方式

1、dao实现类继承SqlSessionDaoSupport

dao接口实现类需要注入SqlSessionFactory,通过spring进行注入。两种方式:自动注入或者声明配置方式;这里使用声明配置方式,配置dao的bean:让UserDaoImpl实现类继承SqlSessionDaoSupport。

  1. public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao{
  2. @override
  3. public User findUserById(int id) throws Exception{
  4. //继承SqlSessionDaoSupport,通过this.getSqlSession()得到sqlSession
  5. SqlSession sqlSession = this.getSqlSession();
  6. User user = sqlSession.selectOne(“test.findUserById”, id);
  7. return user;
  8. <span style="white-space:pre">    </span>}
  9. }
2、配置dao

在applicationContext.xml中配置dao。

  1. <!—原始dao接口 -->
  2. <bean id=”userDao” class=”cn.itcast.ssm.dao.UserDaoImpl”>
  3. <property name=”sqlSessionFactory” ref=”sqlSessionFactory”/>
  4. </bean>
3、测试
  1. public class UserDaoImplTest{
  2. private ApplicationContext applicationContext;
  3. //在setUp这个方法得到spring容器
  4. @Before
  5. public void setUp() throws Exception{
  6. applicationContext = new ClassPathXmlApplicationContext(“classpath:spring/applicationContext”)
  7. <span style="white-space:pre">    </span>}
  8. @Test
  9. public void testFindUserById() throws Exception{
  10. UserDao userDao = (UserDao)applicationContext.getBean(“userDao”);
  11. User user = userDao.findUserById(1);
  12. System.out.println(user);
  13. <span style="white-space:pre">    </span>}
  14. }

五、mapper代理开发方式

1、mapper.xml和mapper.java

  

2、通过MapperFactoryBean创建代理对象
<!—mapper配置MapperFactoryBean:根据mapper接口生成代理对象 -->
<bean id=”userMapper” class=”org.mybatis.spring.mapper.MapperFactoryBean”>
<!--mapperInterface指定mapper接口 -->
<property name=”mapperInterface” value=”cn.itcast.ssm.mapper.UserMapper”/>
<property name=”sqlSessionFactory” ref=”sqlSessionFactory”/>
</bean>

此方法问题:需要针对每个mapper进行配置,麻烦。

3、通过MapperScannerConfigurer进行mapper扫描
<!—加载映射文件 -->  //SqlMapConfig.xml中的
<mappers>
<mapper resource=”sqlmap/User.xml”/>
<!—批量加载mapper
指定mapper接口的包名,mybatis自动扫描包下所有mapper接口进行加载。遵循一些规范:需要将mapper接口类名和mapper.xml映射文件名保持一致,
且在一个目录下。上边规范的前提是:使用 的是mapper代理方法。
和spring整合后,使用mapper扫描器,mybatis的配置文件中就不需要配置了
<!-- <package name=”cn.itcast.ssm.mapper”/> --> //用了下方的Mapper扫描器后,此处的包扫描可以去掉了
-->
</mappers>
<!—mapper批量扫描,从mapper包中扫描出mapper接口,自动创建代理对象并且在spring容器中注册。遵循规范:将mapper.java和mapper.xml映射文件名称保持一致,
且在一个目录中。自动扫描出来的mapper的bean的id为mapper类名(首字母小写) -->
<bean class=”org.mybatis.spring.mapper.MapperScannerConfigurer”>
<!—指定扫描的包名。如果扫描多个包,每个包中间使用半角逗号分隔 -->
<property name=”basePackage” value=”cn.itcast.ssm.mapper”/>
<property name=”sqlSessionFactoryBeanName” value=”sqlSessionFactory”/>
</bean> // 这里name必须用sqlSessionFactoryBeanName而不可以用sqlSessionFactory
//不可以<property name=”sqlSessionFactory” ref=”sqlSessionFactory”/>
// 用像2方法中哪样,否则不优先执行<context:property-placeholder location="classpath:db.properties" />
4、测试代码
    1. @Test
    2. public void testFindUserById() throws Exceptino{
    3. UserMapper userMapper = (userMapper)applicationContext.getBean(“userMapper”);
    4. User user = userMapper.findUserById(1);
    5. System.out.println(user);
    6. }

MyBatis学习七:spring和MyBatis整合的更多相关文章

  1. mybatis学习笔记 spring与mybatis整合

    转载自http://blog.csdn.net/naruto_Mr/article/details/48239357 1.创建web工程,导入spring依赖包与mybatis依赖包,还需要mybat ...

  2. (转)SpringMVC学习(四)——Spring、MyBatis和SpringMVC的整合

    http://blog.csdn.net/yerenyuan_pku/article/details/72231763 之前我整合了Spring和MyBatis这两个框架,不会的可以看我的文章MyBa ...

  3. MyBatis学习 之 一、MyBatis简介与配置MyBatis+Spring+MySql

    目录(?)[-] 一MyBatis简介与配置MyBatisSpringMySql MyBatis简介 MyBatisSpringMySql简单配置 搭建Spring环境 建立MySql数据库 搭建My ...

  4. Quartz学习——SSMM(Spring+SpringMVC+Mybatis+Mysql)和Quartz集成详解(转)

    通过前面的学习,你可能大致了解了Quartz,本篇博文为你打开学习SSMM+Quartz的旅程!欢迎上车,开始美好的旅程! 本篇是在SSM框架基础上进行的. 参考文章: 1.Quartz学习——Qua ...

  5. MyBatis学习 之 四、MyBatis配置文件

    目录(?)[-] 四MyBatis主配置文件 properties属性 settings设置 typeAliases类型别名 typeHandlers类型句柄 ObjectFactory对象工厂 pl ...

  6. 【转】MyBatis学习总结(三)——优化MyBatis配置文件中的配置

    [转]MyBatis学习总结(三)——优化MyBatis配置文件中的配置 一.连接数据库的配置单独放在一个properties文件中 之前,我们是直接将数据库的连接配置信息写在了MyBatis的con ...

  7. 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    [转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...

  8. spring学习 六 spring与mybatis整合

    在mybatis学习中有两种配置文件 :全局配置文件,映射配置文件.mybatis和spring整合,其实就是把mybatis中的全局配置文件的配置内容都变成一个spring容器的一个bean,让sp ...

  9. Spring学习之Spring与Mybatis的两种整合方式

    本机使用IDEA 2020.1.MySql 8.0.19,通过Maven进行构建 环境准备 导入maven依赖包 <dependencies> <dependency> < ...

随机推荐

  1. python之OpenCv(二)---保存图像

    1.使用opencv保存图像 cv2.imwrite(存储路径,图像变量[,存盘标识]) 存盘标识: cv2.CV_IMWRITE_JPEG_QUALITY  设置图片格式为.jpeg或者.jpg的图 ...

  2. vim: 基本知识;

    1. 函数: function!   funcName(para.) content; endfunction 如果添加!,将覆盖已存在的重名函数: 注: 该博文为扩展型: 2.调用外部命令: exe ...

  3. qml: 组件复用

    在编写组件时,使用下面两种方法可以实现组件的复用: import QtQuick 2.0 import QtQuick.Window 2.2 import QtQuick.Controls 1.4 a ...

  4. eslint相关工具

    eslint工具 1. vscode搜索eslint安装,就可以在写代码时报eslint的错误了 2.文件 --> 首选项 --> 设置 --> 选ESLint --> 勾选A ...

  5. C++中string、char *、char[]的转换

    头段时间有人问过我这个问题,可是我一点头绪都没有,直接说不会.现在从网上找了点资料,看了看,知道点东西了. 一.string转char*. 主要有三种方法可以将str转换为char*类型,分别是:da ...

  6. 设计模式---数据结构模式之迭代器模式(Iterate)

    一:概念 迭代模式是行为模式之一,它把对容器中包含的内部对象的访问委让给外部类,使用Iterator(遍历)按顺序进行遍历访问的设计模式. 在应用Iterator模式之前,首先应该明白Iterator ...

  7. java-Array数组常用操作例子(基础必备)

    package com.net.xinfang.reflect; import java.util.ArrayList; import java.util.Arrays; import java.ut ...

  8. Sass map详解

    作为一个CSS预处理器,Sass正受到越来越多的青睐,诸如Github.Codepen.CSS-Tricks.SitePoint.w3cplus等网站采用Sass组织.管理CSS文件,Sass正在逐渐 ...

  9. ipython介绍及使用

    1. IPython介绍 ipython是一个python的交互式shell,比默认的python shell好用得多,支持变量自动补全,自动缩进,支持bash shell命令,内置了许多很有用的功能 ...

  10. centos 6.5 ruby环境安装

    redis3.0以上支持集群,自带集群管理工具redis-trib.rb:在搭建集群前,安装ruby环境 ruby安装包下载 安装开发工具 1.命令:yum groupinstall "De ...