《\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. SpringCloud第二弹(高可用Eureka+Ribbon负载均衡)

    先建立父工程 .. ..一路next 搭建注册中心(需要建立三个工程,端口不一样) .. .. .. 修改入口类 package com.cloud.eurekaserver1111; import ...

  2. 异常处理和Throwable中的几个方法

    package cn.lijun.demo; /* * try { //需要被检测的语句. } catch(异常类 变量) { //参数. //异常的处理语句. } finally { //一定会被执 ...

  3. 微信小程序:分页和加载更多

    直接上代码吧.不足之处,多多指教,一起进步 1.wxml页面的最后敲上,css自己定义 <view class="loadmore" mtype="{{mtype} ...

  4. Hibernate的入门(增删改查):

    注意:本次的记录是在上一篇Hibernate入门的基础上应用的 1.目录 2.实体类修改 package com.itheima.domain; /* * 客户的javaBean * @author ...

  5. angular 中自己常用的下拉框获取值方法

    方法一 HTML页中 <select name="" id="if02" data-first-option="true" (chan ...

  6. 访问内网(https,udp)

    安装teamview 客户端. 安装vpn驱动(这里的VPN应该是A主机与B客户端分别连接上了teamview的服务器,但是本身不是局域 网,所以不能直接访问A的局域网的其他主机) 主机端A,安装主机 ...

  7. 【openssl】利用openssl完成X509证书和PFX证书之间的互转

    利用openssl完成X509证书和PFX证书之间的互转 # OpenSSL的下载与安装: 1.下载地址: 官方网址—— https://www.openssl.org/source/ OpenSSL ...

  8. Centos6.6搭建Maven私服

    操作系统:Centos6.6 私服Ip:10.0.210.112 JDK:1.7 (已安装并配置好了环境变量) 1:上 传 nexus-2.11.2-03-bundle.tar.gz到/root/ne ...

  9. Docker 容器管理

    单一容器管理 容器的标识符 每个容器被创建后都会分配一个CONTAINER_ID作为容器的唯一标识符,后续的启动.停止等操作都通过CONTAINER_ID来完成的. CONTAINER_ID很难记忆, ...

  10. C#设计模式(10)——桥接模式

    1.桥接模式介绍 桥接模式用于将抽象化和实现化解耦,使得两者可以独立变化.在面向对象中用通俗的话说明:一个类可以通过多角度来分类,每一种分类都可能变化,那么就把多角度分离出来让各个角度都能独立变化,降 ...