>Java >java지도 시간 >Spring+SpringMVC+MyBatis 심층 학습 및 구성 - MyBatis 및 Spring 통합

Spring+SpringMVC+MyBatis 심층 학습 및 구성 - MyBatis 및 Spring 통합

巴扎黑
巴扎黑원래의
2017-06-26 09:26:261576검색

재인쇄할 소스를 표시해 주세요:

앞서 언급한 대로: Spring+SpringMVC+MyBatis 심층 학습 및 구성(8) - MyBatis 쿼리 캐시

1. 통합 아이디어

Spring에서는 싱글톤을 통해 SqlSessionFactory를 관리해야 합니다.

Spring과 MyBatis는 통합되어 프록시 객체를 생성하고 SqlSessionFactory를 사용하여 SqlSession을 생성합니다. (Spring과 MyBatis의 통합은 자동으로 완료됩니다.)

퍼시스턴스 레이어의 매퍼는 Spring에서 관리해야 합니다.

2. 환경 통합

Java 프로젝트 생성(실제 개발 프로젝트 구조와 유사)

jar 패키지:

mybatis3.2.7 jar 패키지

spring3.2.0 jar 패키지

dbcp 연결 풀

데이터베이스 드라이버

mybatis와 spring의 통합 패키지: ibatis와 spring의 초기 통합은 spring에서 공식적으로 제공되었고, mybatis와 spring의 통합은 mybatis에서 제공되었습니다.

3.spring 구성 파일

applicationContext.xml에서 sqlSessionFactory 및 데이터 소스를 구성합니다. SqlSessionFactory는 mybatis와 spring의 통합 패키지 아래에 있습니다. Mapper에 의해 작성된 3 가지 방법

4.1 원래 DAO 개발 (스프링과 통합 후)

4.1.1user.xml

<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"xsi:schemaLocation="http://www.springframework.org/schema/beans 
         
         
         
         
         
         
         
         
         "><!-- 加载配置文件 --><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}"/><property name="url" value="${jdbc.url}"/><property name="username" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/><property name="maxActive" value="10"/><property name="maxIdle" value="5"/></bean><!-- SqlSessionFactory配置 --><!-- 让Spring管理SqlSessionFactory使用mybatis和spring整合包中的 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><!-- 数据库连接池 --><property name="dataSource" ref="dataSource" /><!-- 加载mybatis的全局配置文件 --><property name="configLocation" value="classpath:mybatis/SqlMapConfig.xml" /></bean></beans>
user.xml에서 sqlmapconfig.xml


.

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!--namespace命名空间,作用就是对sql进行分类化的管理,理解为sql隔离
    注意:使用mapper代理开发时,namespace有特殊作用  --><mapper namespace="test"><!--在映射文件中配置很多sql语句  --><!--需求:通过id查询用户表的记录  --><!--id:标识映射文件中的sql,称为statement的id。将sql语句封装在mapperStatement的对象中,所有id称为Statement的id;
        parameterType:指定输入参数的类型,这里指定int型;
        #{}:表示一个占位符;
        #{id}:其中id表示接收输入的参数,参数名称就是id,如果输入参数是简单类型,#{}中的参数名可以任意,可以是value或其它名称;
        resultType:指定输出结果所映射的Java对象类型,select指定resultType表示将单条记录映射成Java对象。      --><select id="findUserById" parameterType="int" resultType="joanna.yan.po.User">select * from user where id=#{value}</select> </mapper>
4.1.2 dao(구현 클래스는 SqlSessionDaoSupport를 상속함)


<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
 <configuration>  <!-- 
      批量别名的定义:
      package:指定包名,mybatis会自动扫描包中的pojo类,自定义别名,别名就是类名(首字母大写或小写都可以) -->  <typeAliases>  <package name="joanna.yan.po"/>  </typeAliases><mappers><mapper resource="sqlmap/User.xml"/><!-- 批量加载映射配置文件,mybatis自动扫描包下的mapper接口进行加载;
            遵循一定的规范:需要将mapper接口类名和mapper.xml映射文件名称保持一致,且在一个目录中;
            以上规范的前提是:使用的是mapper代理方法;          --><package name="joanna.yan.mapper"/></mappers>
 </configuration>
dao 인터페이스 구현 클래스는 스프링을 통해 SqlSessionFactory를 주입해야 합니다.

여기에서는 스프링 선언 구성 방법을 사용하여 dao bean을 구성합니다.

UserDaoImpl 구현 클래스가 SqlSessionDaoSupport를 상속하도록 합니다.

public interface UserDao {//根据id查询用户信息public User findUserById(int id) throws Exception;
}
4.1.3 dao 구성applicationContext.xml에서 dao를 구성하세요.


public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao{

    @Overridepublic User findUserById(int id) throws Exception {//继承SqlSessionDaoSupport,通过this.getSqlSession()得到sqlSessionSqlSession sqlSession=this.getSqlSession();
        User user=sqlSession.selectOne("test.findUserById", id);return user;
    }
}

4.1.4 테스트 프로그램


    <!-- 方法一:原始dao接口  --><bean id="userDao" class="joanna.yan.dao.UserDaoImpl"><property name="sqlSessionFactory" ref="sqlSessionFactory" /></bean>
4.2mapper 에이전트 개발

4.2.1mapper.xml 및 mapper.java


public class UserDaoImplTest {private ApplicationContext applicationContext;
    
    @Beforepublic void setUp(){
        applicationContext=new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");
    }
    
    @Testpublic void findUsetByIdTest() throws Exception{
        UserDao userDao=(UserDao) applicationContext.getBean("userDao");
        User user=userDao.findUserById(1);
        System.out.println(user);
    }
}

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!--namespace命名空间,作用就是对sql进行分类化的管理,理解为sql隔离
    注意:使用mapper代理开发时,namespace有特殊作用,namespace等于mapper接口地址  --><mapper namespace="joanna.yan.mapper.UserMapper"><select id="findUserById" parameterType="int" resultType="user">select * from user where id=#{value}</select></mapper>

4.2.2(MapperFactoryBean을 통해) 프록시 객체를 생성하세요

applicationContext.xml에서 매퍼를 구성하세요.


public interface UserMapper {public User findUserById(int id) throws Exception;
}

4.2.3 테스트 프로그램


    <!-- 方法二:mapper配置
         MapperFactoryBean:根据mapper接口生成代理对象     --><bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean"><property name="mapperInterface" value="joanna.yan.mapper.UserMapper" /><property name="sqlSessionFactory" ref="sqlSessionFactory" /></bean>
이 방법의 문제점: 각 매퍼마다 구성해야 한다는 점이 번거롭습니다.

4.3 MapperScannerConfigurer를 통한 매퍼 스캐닝(권장)


applicationContext.xml에서 매퍼 일괄 스캐닝을 구성합니다.

public class UserMapperTest {private ApplicationContext applicationContext;
    
    @Beforepublic void setUp(){
        applicationContext=new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");
    }
    
    @Testpublic void findUsetByIdTest() throws Exception{
        UserMapper userMapper=(UserMapper) applicationContext.getBean("userMapper");
        User user=userMapper.findUserById(1);
        System.out.println(user);
    }
}

이때 SqlMapConfig.xml의 joanna.yan.mapper 하위 배치 로딩 매퍼 구성은 생략 가능합니다.


테스트 절차:

    <!-- 方法三:mapper批量扫描 
          从mapper包中扫描出mapper接口,自动创建代理对象并且在spring容器中注册
          遵循规范:将mapper.java和mapper.xml映射文件名称保持一致,且在一个目录中。
         自动扫描出来的mapper的bean的id为mapper类名(首字母小写)     --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!-- 指定扫描的包名
             如果扫描多个包,每个包中间使用半角逗号分隔          --><property name="basePackage" value="joanna.yan.mapper"/><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/></bean>

위 내용은 Spring+SpringMVC+MyBatis 심층 학습 및 구성 - MyBatis 및 Spring 통합의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.