@

Mybatis整合spring其实就是SSM框架中SM的整合集成。

1.整合思路

整合的思路其实就是Mybatis整合spring的核心

1、SqlSessionFactory对象应该放到spring容器中作为单例存在,spring默认是单例的。

2、传统dao的开发方式中,应该从spring容器中获得sqlsession对象。

3、Mapper代理形式中,应该从spring容器中直接获得mapper的代理对象。

4、数据库的连接以及数据库连接池事务管理都交给spring容器来完成。

2.整合需要的jar包

1、spring的jar包

2、Mybatis的jar包

3、Spring+mybatis的整合包。

4、Mysql的数据库驱动jar包。

5、数据库连接池的jar包。

jar包的话,希望在座各位最好都有,不然我就很尴尬QAQ

3.整合的步骤

3.1.创建工程

如下图创建一个java工程:

3.2.导入jar包

前面提到的jar包需要导入,如下图:

3.3.加入配置文件

1.mybatisSpring的配置文件

2.的配置文件sqlmapConfig.xml

a)数据库连接及连接池

b)事务管理(暂时可以不配置)

c)sqlsessionFactory对象,配置到spring容器中

d)mapeer代理对象或者是dao实现类配置到spring容器中。

创建资源文件夹config拷贝加入配置文件,如下图

3.3.1.配置SqlMapConfig.xml

配置文件是SqlMapConfig.xml,如下:

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE configuration
  3. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-config.dtd">
  5. <configuration>
  6. <!-- 设置别名 -->
  7. <typeAliases>
  8. <!-- 2. 指定扫描包,会把包内所有的类都设置别名,别名的名称就是类名,大小写不敏感 -->
  9. <package name="com.gx.mybatis.pojo" />
  10. </typeAliases>
  11. </configuration>
3.3.2.applicationContext.xml

SqlSessionFactoryBean属于mybatis-spring这个jar包

对于spring来说,mybatis是另外一个架构,需要整合jar包。

在项目中加入mybatis-spring-1.2.2.jar的源码,如下图



效果,如下图所示,图标变化,表示源码加载成功:



整合Mybatis需要的是SqlSessionFactoryBean,位置如下图:

applicationContext.xml,配置内容如下

由于是原始Dao开发,所以

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"
  4. xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
  5. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
  7. http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
  8. http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
  9. http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
  10. <!-- 加载配置文件 -->
  11. <context:property-placeholder location="classpath:db.properties" />
  12. <!-- 数据库连接池 -->
  13. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  14. destroy-method="close">
  15. <property name="driverClassName" value="${jdbc.driver}" />
  16. <property name="url" value="${jdbc.url}" />
  17. <property name="username" value="${jdbc.username}" />
  18. <property name="password" value="${jdbc.password}" />
  19. <property name="maxActive" value="10" />
  20. <property name="maxIdle" value="5" />
  21. </bean>
  22. <!-- 配置SqlSessionFactory -->
  23. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  24. <!-- 配置mybatis核心配置文件 -->
  25. <property name="configLocation" value="classpath:SqlMapConfig.xml" />
  26. <!-- 配置数据源 -->
  27. <property name="dataSource" ref="dataSource" />
  28. </bean>
  29. </beans>
3.3.3.配置db.properties
  1. jdbc.driver=com.mysql.jdbc.Driver
  2. jdbc.url=jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8
  3. jdbc.username=root
  4. jdbc.password=root
3.3.4.配置log4j.properties
  1. # Global logging configuration
  2. log4j.rootLogger=DEBUG, stdout
  3. # Console output...
  4. log4j.appender.stdout=org.apache.log4j.ConsoleAppender
  5. log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
  6. log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n
3.3.5.效果:

加入的配置文件最终效果如下:



至此环境就搭建OK了!!!!

4.Dao的开发的两种实现方式

1、原始dao的开发方式

2、使用Mapper代理形式开发方式

a)直接配置Mapper代理

b)使用扫描包配置Mapper代理

需求:

1.实现根据用户id查询

2.实现根据用户名模糊查询

3.添加用户

4.1.创建pojo

  1. public class User {
  2. private int id;
  3. private String username;// 用户姓名
  4. private String sex;// 性别
  5. private Date birthday;// 生日
  6. private String address;// 地址
  7. get/set。。。
  8. }

4.2.传统dao的开发方式(方式一)

原始的DAO开发接口+实现类来完成。

需要dao实现类需要继承SqlsessionDaoSupport类

4.2.1.实现Mapper.xml

编写User.xml配置文件,如下:

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="test">
  6. <!-- 根据用户id查询 -->
  7. <select id="queryUserById" parameterType="int" resultType="user">
  8. select * from user where id = #{id}
  9. </select>
  10. <!-- 根据用户名模糊查询用户 -->
  11. <select id="queryUserByUsername" parameterType="string"
  12. resultType="user">
  13. select * from user where username like '%${value}%'
  14. </select>
  15. <!-- 添加用户 -->
  16. <insert id="saveUser" parameterType="user">
  17. <selectKey keyProperty="id" keyColumn="id" order="AFTER"
  18. resultType="int">
  19. select last_insert_id()
  20. </selectKey>
  21. insert into user
  22. (username,birthday,sex,address)
  23. values
  24. (#{username},#{birthday},#{sex},#{address})
  25. </insert>
  26. </mapper>
4.2.2.加载Mapper.xml

在SqlMapConfig如下图进行配置:

4.2.3.实现UserDao接口
  1. public interface UserDao {
  2. /**
  3. * 根据id查询用户
  4. *
  5. * @param id
  6. * @return
  7. */
  8. User queryUserById(int id);
  9. /**
  10. * 根据用户名模糊查询用户列表
  11. *
  12. * @param username
  13. * @return
  14. */
  15. List<User> queryUserByUsername(String username);
  16. /**
  17. * 保存
  18. *
  19. * @param user
  20. */
  21. void saveUser(User user);
  22. }
4.2.4.编写UserDaoImpl实现接口并且继承SqlSessionDaoSupport

编写DAO实现类,实现类必须继承SqlSessionDaoSupport

SqlSessionDaoSupport提供getSqlSession()方法来获取SqlSession

  1. public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao {
  2. @Override
  3. public User queryUserById(int id) {
  4. // 获取SqlSession
  5. SqlSession sqlSession = super.getSqlSession();
  6. // 使用SqlSession执行操作
  7. User user = sqlSession.selectOne("queryUserById", id);
  8. // 不要关闭sqlSession
  9. return user;
  10. }
  11. @Override
  12. public List<User> queryUserByUsername(String username) {
  13. // 获取SqlSession
  14. SqlSession sqlSession = super.getSqlSession();
  15. // 使用SqlSession执行操作
  16. List<User> list = sqlSession.selectList("queryUserByUsername", username);
  17. // 不要关闭sqlSession
  18. return list;
  19. }
  20. @Override
  21. public void saveUser(User user) {
  22. // 获取SqlSession
  23. SqlSession sqlSession = super.getSqlSession();
  24. // 使用SqlSession执行操作
  25. sqlSession.insert("saveUser", user);
  26. // 不用提交,事务由spring进行管理
  27. // 不要关闭sqlSession
  28. }
  29. }
4.2.4.1.SqlSessionDaoSupport源码

实现类必须继承SqlSessionDaoSupportSqlSessionDaoSupport提供getSqlSession()方法来获取SqlSession

4.2.5.配置dao

把dao实现类配置到spring容器中

  1. <!-- Dao原始Dao -->
  2. <bean id="userDao" class="com.gx.mybatis.dao.UserDaoImpl">
  3. <property name="sqlSessionFactory" ref="sqlSessionFactoryBean"/>
  4. </bean>
4.2.6.创建测试

创建测试方法,可以直接创建测试Junit用例。

如下图所示进行创建。





编写测试方法如下:

  1. public class UserDaoTest {
  2. private ApplicationContext context;
  3. @Before
  4. public void setUp() throws Exception {
  5. this.context = new ClassPathXmlApplicationContext("classpath:applicationContext.xml");
  6. }
  7. @Test
  8. public void testQueryUserById() {
  9. // 获取userDao
  10. UserDao userDao = this.context.getBean(UserDao.class);
  11. User user = userDao.queryUserById(1);
  12. System.out.println(user);
  13. }
  14. @Test
  15. public void testQueryUserByUsername() {
  16. // 获取userDao
  17. UserDao userDao = this.context.getBean(UserDao.class);
  18. List<User> list = userDao.queryUserByUsername("张");
  19. for (User user : list) {
  20. System.out.println(user);
  21. }
  22. }
  23. @Test
  24. public void testSaveUser() {
  25. // 获取userDao
  26. UserDao userDao = this.context.getBean(UserDao.class);
  27. User user = new User();
  28. user.setUsername("夏侯惇坑");
  29. user.setSex("1");
  30. user.setBirthday(new Date());
  31. user.setAddress("三国");
  32. userDao.saveUser(user);
  33. System.out.println(user);
  34. }
  35. }

5.Mapper代理形式开发dao(方式二)

5.1.实现Mapper.xml

编写UserMapper.xml配置文件,如下:

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="cn.itcast.mybatis.mapper.UserMapper">
  6. <!-- 根据用户id查询 -->
  7. <select id="queryUserById" parameterType="int" resultType="user">
  8. select * from user where id = #{id}
  9. </select>
  10. <!-- 根据用户名模糊查询用户 -->
  11. <select id="queryUserByUsername" parameterType="string"
  12. resultType="user">
  13. select * from user where username like '%${value}%'
  14. </select>
  15. <!-- 添加用户 -->
  16. <insert id="saveUser" parameterType="user">
  17. <selectKey keyProperty="id" keyColumn="id" order="AFTER"
  18. resultType="int">
  19. select last_insert_id()
  20. </selectKey>
  21. insert into user
  22. (username,birthday,sex,address) values
  23. (#{username},#{birthday},#{sex},#{address})
  24. </insert>
  25. </mapper>
5.2.实现UserMapper接口
  1. public interface UserMapper {
  2. /**
  3. * 根据用户id查询
  4. *
  5. * @param id
  6. * @return
  7. */
  8. User queryUserById(int id);
  9. /**
  10. * 根据用户名模糊查询用户
  11. *
  12. * @param username
  13. * @return
  14. */
  15. List<User> queryUserByUsername(String username);
  16. /**
  17. * 添加用户
  18. *
  19. * @param user
  20. */
  21. void saveUser(User user);
  22. }
5.3.方式一:配置mapper代理

在applicationContext.xml添加配置

MapperFactoryBean也是属于mybatis-spring整合包

  1. <!-- Mapper代理的方式开发方式一,配置Mapper代理对象 -->
  2. <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
  3. <!-- 配置Mapper接口 -->
  4. <property name="mapperInterface" value="com.gx.mybatis.mapper.UserMapper" />
  5. <!-- 配置sqlSessionFactory -->
  6. <property name="sqlSessionFactory" ref="sqlSessionFactory" />
  7. </bean>
5.4.创建测试
  1. public class UserMapperTest {
  2. private ApplicationContext context;
  3. @Before
  4. public void setUp() throws Exception {
  5. this.context = new ClassPathXmlApplicationContext("classpath:applicationContext.xml");
  6. }
  7. @Test
  8. public void testQueryUserById() {
  9. // 获取Mapper
  10. UserMapper userMapper = this.context.getBean(UserMapper.class);
  11. User user = userMapper.queryUserById(1);
  12. System.out.println(user);
  13. }
  14. @Test
  15. public void testQueryUserByUsername() {
  16. // 获取Mapper
  17. UserMapper userMapper = this.context.getBean(UserMapper.class);
  18. List<User> list = userMapper.queryUserByUsername("张");
  19. for (User user : list) {
  20. System.out.println(user);
  21. }
  22. }
  23. @Test
  24. public void testSaveUser() {
  25. // 获取Mapper
  26. UserMapper userMapper = this.context.getBean(UserMapper.class);
  27. User user = new User();
  28. user.setUsername("安琪拉稀");
  29. user.setSex("1");
  30. user.setBirthday(new Date());
  31. user.setAddress("中国");
  32. userMapper.saveUser(user);
  33. System.out.println(user);
  34. }
  35. }
5.5.方式二:扫描包形式配置mapper(开发常用)
  1. <!-- Mapper代理的方式开发方式二,扫描包方式配置代理 -->
  2. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  3. <!-- 配置Mapper接口 -->
  4. <property name="basePackage" value="com.gx.mybatis.mapper" />
  5. </bean>

每个mapper代理对象的id就是类名,首字母小写

6、Dao的开发的实现方式总结图

Mybatis整合spring(适合小白)的更多相关文章

  1. Mybatis整合spring详细教程(适合小白童鞋)

    目录 1.整合思路 2.整合需要的jar包 3.整合的步骤 4.Dao的开发的两种实现方式 6.Dao的开发的实现方式总结图 @ Mybatis整合spring其实就是SSM框架中SM的整合集成. 1 ...

  2. mybatis整合spring 之 基于接口映射的多对一关系

    转载自:http://my.oschina.net/huangcongmin12/blog/83731 mybatis整合spring 之  基于接口映射的多对一关系. 项目用到俩个表,即studen ...

  3. mybatis整合spring获取配置文件信息出错

    描述:mybatis整合spring加载jdbc.properties文件,然后使用里面配置的值来 配置数据源,后来发现用户变成了admin- jdbc.properties的配置: 加载配置: 报错 ...

  4. JAVAEE——Mybatis第二天:输入和输出映射、动态sql、关联查询、Mybatis整合spring、Mybatis逆向工程

    1. 学习计划 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If标签 b) Where标签 c) Sql片段 d) Foreach标签 3.关联查询 a) 一对 ...

  5. Mybatis整合Spring -- typeAliasesPackage

    Mybatis整合Spring 根据官方的说法,在ibatis3,也就是Mybatis3问世之前,Spring3的开发工作就已经完成了,所以Spring3中还是没有对Mybatis3的支持. 因此由M ...

  6. 160330、Mybatis整合Spring

    转自csdn文章 http://haohaoxuexi.iteye.com/blog/1843309 Mybatis整合Spring 根据官方的说法,在ibatis3,也就是Mybatis3问世之前, ...

  7. (转)MyBatis框架的学习(六)——MyBatis整合Spring

    http://blog.csdn.net/yerenyuan_pku/article/details/71904315 本文将手把手教你如何使用MyBatis整合Spring,这儿,我本人使用的MyB ...

  8. 不需要怎么修改配置的Mybatis整合Spring要点

    首先对于Mybatis的主配置文件,只需要修改一处地方,将事务交给Spring管理,其它地方可以原封不动. <?xml version="1.0" encoding=&quo ...

  9. JavaWeb_(Mybatis框架)MyBatis整合Spring框架

    MyBatis + Spring整合开发 a)使用Spring容器用单例模式管理Mybatis的sqlSessionFactory:b)使用Spring管理连接池.数据源等:c)将Dao/Mapper ...

随机推荐

  1. anaconda重装jupyter notebook后启动jupyter报错的问题

    问题描述: 由于jupyter出现难以解决的问题,采用重新安装来解决问题,但是重装之后启动jupyter报错ImportError: libsodium.so.23: cannot open shar ...

  2. Mycat分布式数据库架构解决方案--Linux安装运行Mycat

    echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! Myc ...

  3. oracle 特殊符号替换删除处理

    1 获取ascii码 select ascii('特殊字符') from dual 2 替换 update table set testfield= replace(testfield,chr(asc ...

  4. asp.net core Api集成Swagger

    当我们通过vs创建了一个api项目后,便可以开始集成swagger了 一.Swagger集成 从“程序包管理器控制台”窗口进行安装,执行Install-Package Swashbuckle.AspN ...

  5. C++学习笔记13_操作MySql

    1. 链接Mysql #include <winsock.h>#include "mysql.h"#include <stdlib.h>#include & ...

  6. [考试反思]1029csp-s模拟测试93:殇逝

    并不是把它消成上三角矩阵 停止! 思考, 回顾. 疑惑? 遗忘… 一直只是在匆忙的赶进度,实际上的确是一点也不扎实. T1,裸的偏序,想了一个多小时什么也没想到,只打了$O(n^2)$ 难道之前学的就 ...

  7. Windows Server 搭建企业无线认证(Radius认证方案)

    认证协议介绍: 扩展认证协议EAP(Extensible Authentication Protocol) 是一个在无线网络或点对点连线中普遍使用的认证框架.它被定义在RFC 3748中,并且使RFC ...

  8. PCA降维的原理、方法、以及python实现。

    PCA(主成分分析法) 1. PCA(最大化方差定义或者最小化投影误差定义)是一种无监督算法,也就是我们不需要标签也能对数据做降维,这就使得其应用范围更加广泛了.那么PCA的核心思想是什么呢? 例如D ...

  9. Servlet——用户登录案例

    案例:用户登录 * 用户登录案例需求: 1.编写login.html登录页面 username & password 两个输入框 2.使用Druid数据库连接池技术,操作mysql,day14 ...

  10. JavaScript中BOM与DOM的使用

    BOM: 概念:Browser Object Model 浏览器对象模型 将浏览器的各个组成部分封装成对象. 组成: Window:窗口对象 Navigator:浏览器对象 Screen:显示器屏幕对 ...