MyBatis로 봄 통합은 주요 문제는 봄에 넘겨 SqlSessionFactory는 해결하는 것입니다
관리 할 수 있습니다. 따라서 단지 객체 생성 SqlSessionFactoryBean SqlSessionFactory는 참고로, 통합
후 통합을 완료하기 위해 DAO 구현 클래스에 주입, 책 Spring 컨테이너.
봄의 MyBatis는 일반적인 방법을 통합 : 동적 프록시는 매퍼 스캔
쉽게 함께 결합 될 수 패치 패널, 프레임의 MyBatis 플러그로 봄 이미지. 플러그가 삽입 된 판 스프링
의 MyBatis에 두 틀 전체이다.
MySQL은 데이터베이스 springdb를 작성 4.1.1 새 테이블 학생
4.1.2 받는다는의 pom.xml 의존
<? XML 버젼 = "1.0"인코딩 = "UTF-8" ?> < 프로젝트 의 xmlns = "http://maven.apache.org/POM/4.0.0" 의 xmlns :이 xsi = "http://www.w3.org / 2001 / 된 XMLSchema 인스턴스 " 는 xsi :의 schemaLocation ="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd " > < modelVersion > 4.0.0 </ modelVersion > < 의 groupId > com.bjpowernode </ 의 groupId > < artifactId를 > ch09-스프링의 MyBatis </ artifactId를 > <</ 버전 > < 이름 > ch09 - 봄의 MyBatis </ 이름 > <! - FIXME 프로젝트의 웹 사이트로 변경 -> < URL > http://www.example.com </ URL > < 속성 > < project.build.sourceEncoding > UTF-8 </ project.build.sourceEncoding > < maven.compiler.source > 1.8 </ maven.compiler.source > < maven.compiler.target > 1.8 </ maven.compiler.target> </ 속성 > < 의존성 > < 의존성 > < 의 groupId > 의 JUnit </ 의 groupId > < artifactId를 > 스프링 컨텍스트 </ artifactId를 > < 버전 > 4.3.16.RELEASE </ 버전 > 스프링访问数据库-> < 의존성 > < 의 groupId > org.springframework </ 의 groupId > < artifactId를 > 스프링 JDBC </ artifactId를 > < 버전 > 4.3.16.RELEASE </ 버전 > </ 의존성 > <! - 의 MyBatis的依赖-> < 의존성 > < 의 groupId > org.mybatis </ 의 groupId > < artifactId를 > 의 MyBatis </ artifactId를 의 groupId > MySQL의 </ 의 groupId > < artifactId를 > MySQL의 커넥터 - 자바 </ artifactId를 > < 버전 > 5.1.9 </ 버전 > </ 의존성 > <! - 数据库连接池-> < 의존성 > < 의 groupId > COM .alibaba </ 의 groupId > < artifactId를 > 사제 </ artifactId를 > < 버전 > 1.1.12을 </ 버전> </ 종속성 > </ 종속성 > < 빌드 > < 참고 자료 > < 리소스 > <에게 디렉토리 > SRC / 메인 / 자바는 </ 디렉토리 > <! - 디렉토리가 위치한 -> < 포함 > <! - 포함 디렉토리 .properties입니다가, .XML 파일을 스캔 -> <이 (가) 포함 > . ** / * 속성을 </ 포함 > < 인클루드 > . ** / * XML </ (가) 포함 > </ 포함 > < 필터 > 거짓 </ 필터링 > > </ 구축 > </ 프로젝트 >
4.1.3 학생 클래스 정의 엔티티
4.1.4 정의 StudentDao
4.1.5 매핑 파일 매퍼를 정의
다오이 경우, 동일한 이름의 인터페이스 매퍼의 MyBatis 매핑 파일 및 인터페이스의 이름으로 패키지에 생성
StudentDao.xml. 네임 스페이스 값 매퍼는 또한 인터페이스 다오의 완전한 이름입니다.
4.1.6 서비스 정의
인터페이스 정의 :
구현 클래스 정의 :
4.1.7 정의의 MyBatis
MyBatis로 마스터 프로필은 SRC라는 mybatis.xml에 정의.
주목해야 할 두 지점이 있습니다 :
(1) 메인 프로파일 데이터 소스가 더 이상 필요하지 배치. 데이터 소스 때문에 당신은 스프링 컨테이너를 관리 할.
(2) <패키지 /> 태그, 즉 단지 주어진 매퍼 매핑 파일 사용 매퍼 매핑 파일을 등록 여기서
호스트 패키지. 다오 인터페이스 이름 매퍼 같은 방식으로 이름을 때문에이 간단한 등록을 사용할 수 있습니다. 이
혜택의 접근 방식은 여러 맵 파일 경우, 여기에 구성이 변경되지 않는 것입니다. 물론, 가능도 원래 사용하는
<자원 /> 태그 모드.
Spring 설정 파일을 수정 4.1.8
(1) 구성 데이터 소스 (마스터)
使用 JDBC 模板,首先需要配置好数据源,数据源直接以 Bean 的形式配置在 Spring 配
置文件中。根据数据源的不同,其配置方式不同:
Druid 数据源 DruidDataSource
Druid 是阿里的开源数据库连接池。是 Java 语言中最好的数据库连接池。Druid 能
够提供强大的监控和扩展功能。Druid 与其他数据库连接池的最大区别是提供数据库的
官网:https://github.com/alibaba/druid
使用地址:https://github.com/alibaba/druid/wiki/常见问题
配置连接池:
Spring 配置文件:
(2 ) 从属性文件读取数据库连接信息
为了便于维护,可以将数据库连接信息写入到属性文件中,使 Spring 配置文件从中读取
数据。
属性文件名称自定义,但一般都是放在 src 下。
Spring 配置文件从属性文件中读取数据时,需要在<property/>的 value 属性中使用${ },
将在属性文件中定义的 key 括起来,以引用指定属性的值。
该属性文件若要被 Spring 配置文件读取,其必须在配置文件中进行注册。使用<context>
标签。
<context:property-placeholder/> 方式(掌握)
该方式要求在 Spring 配置文件头部加入 spring-context.xsd 约束文件
<context:property-placeholder/>标签中有一个属性 location,用于指定属性文件的位置。
(3 ) 注册 SqlSessionFactoryBean
(4 ) 定义 Mapper 扫描配置器 MapperScannerConfigurer
Mapper 扫描配置器 MapperScannerConfigurer 会自动生成指定的基本包中 mapper 的代
理对象。该 Bean 无需设置 id 属性。basePackage 使用分号或逗号设置多个包。
4.1.9 向 向 Service
向 Service 注入 Mapper 代理对象时需要注意,由于通过 Mapper 扫描配置器
MapperScannerConfigurer 生成的 Mapper 代理对象没有名称,所以在向 Service 注入 Mapper
代理时,无法通过名称注入。但可通过接口的简单类名注入,因为生成的是这个 Dao 接口
的对象。
4.1.10 Spring 配置文件的全部配置