SpringBoot 가 jdbc 와 my batis 를 통합 하 는 방법

일반 설정\#
다음은 JDBC 통합 과 MyBatis 통합 에 필요 한 실체 클래스 와 설정 을 소개 합 니 다.
데이터베이스 테이블\#

CREATE TABLE `user` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `username` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL,
 `address` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL,
 PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

SET FOREIGN_KEY_CHECKS = 1;
실체 클래스\#
간단 한 User 실체 클래스 를 추가 하여 아래 jdbc 와 my batis 의 사용 과 테스트 에 사용 합 니 다.toString 방법 을 하나 더 추가 하 겠 습 니 다.

public class User {
 private Integer id;
 private String username;
 private String address;
 public Integer getId() { return id; }
 public void setId(Integer id) { this.id = id; }
 public String getUsername() { return username; }
 public void setUsername(String username) { this.username = username; }
 public String getAddress() { return address; }
 public void setAddress(String address) { this.address = address; }
 @Override
 public String toString() {
  return "User{" +
    "id=" + id +
    ", username='" + username + '\'' +
    ", address='" + address + '\'' +
    '}';
 }
}

maven 설정\#
my sql 버 전 은 자신의 데이터베이스 버 전에 따라 설정 합 니 다.
druid 가 아 리 클 라 우 드 에 제공 하 는 데이터 원본(연결 풀 로 이해 가능)

<dependency>
 <groupId>com.alibaba</groupId>
 <artifactId>druid-spring-boot-starter</artifactId>
 <version>1.1.10</version>
</dependency>
<dependency>
 <groupId>mysql</groupId>
 <artifactId>mysql-connector-java</artifactId>
 <scope>runtime</scope>
 <version>8.0.18</version>
</dependency>
데이터베이스 설정\#
데이터베이스 properties 설정 이 적지 않 을 겁 니 다.

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.username=username
spring.datasource.password=password
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/mydatabase
통합 JDBC\#
maven 의존\#
springboot 에서 제공 하 는 jdbc 의존 도 를 추가 합 니 다.

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-data-jdbc</artifactId>
</dependency>
사용\#

@Service
public class UserService {

 @Autowired
 JdbcTemplate jdbcTemplate;

 public Integer addUser(User user) {
  return jdbcTemplate.update("insert into user (username,address) values (?,?);",
    user.getUsername(), user.getAddress());
 }

 /**
  *      
  *                    
  * @return
  */
 public List<User> getAllUserFirst() {
  return jdbcTemplate.query("select * from user;", new RowMapper<User>() {
   @Override
   public User mapRow(ResultSet resultSet, int i) throws SQLException {
    User user = new User();
    int id = resultSet.getInt("id");
    String address = resultSet.getString("address");
    String username = resultSet.getString("username");
    user.setId(id);
    user.setUsername(username);
    user.setAddress(address);
    return user;
   }
  });
 }

 /**
  *      
  *                    ,        
  */
 public List<User> getAllUserSecond() {
  return jdbcTemplate.query("select * from user;", new BeanPropertyRowMapper<>(User.class));
 }
}

jdbc 는 새로 추가 되 든 수정 되 든 삭제 되 든 모두 update 방법 을 사용 한 다 는 것 을 기억 해 야 합 니 다.검색 은 query 를 사용 합 니 다.
데이터베이스 필드 와 실체 클래스 속성 이 일치 하지 않 을 경우 위 코드 의 조회 방식 1 을 사용 해 야 합 니 다.
만약 에 데이터베이스 필드 와 실체 류 속성 이 모두 일치 할 때 상기 코드 중의 조회 방식 2 를 사용 하여 간단 하고 빠르다.
테스트\#
정리 가 끝 난 후에 당연히 테스트 를 적 게 보충 한 것 입 니 다.테스트 유형 은 다음 과 같 습 니 다.

@SpringBootTest
class JdbcApplicationTests {

 @Autowired
 UserService userService;

 @Test
 public void addUser() {
  User user = new User();
  user.setUsername("johnson2");
  user.setAddress("colablog.cn");
  userService.addUser(user);
 }

 public void queryUsers() {
  List<User> allUserFirst = userService.getAllUserFirst();
  System.out.println(allUserFirst);
 }
}

MyBatis 통합\#
현재 가장 유행 하 는 지구 층 프레임 워 크 마 이 바 티 스 는 매일 SSM 으로 귀 에 못 이 박 히 는 소 리 를 들 었 다.MyBatis 통합 은 가장 많이 사 용 될 수 있 습 니 다.다음 과 같이 통합 합 니 다.
maven 의존\#
버 전 은 Maven 창 고 를 볼 수 있 습 니 다.

<dependency>
 <groupId>org.mybatis.spring.boot</groupId>
 <artifactId>mybatis-spring-boot-starter</artifactId>
 <version>2.1.1</version>
</dependency>
검색 Mapper\#
SpringBoot 에 mapper 경 로 를 제공 해 야 합 니 다.제 가방 스 캔 경 로 는 cn.colablog.my batis.mapper 입 니 다.
방식 1:설정 항목 추가

@Configuration
@MapperScan(basePackages = "cn.colablog.mybatis.mapper")
public class MyBatisConfig {
}
방식 2:애플 리 케 이 션 에 직접 설정

@SpringBootApplication
@MapperScan(basePackages = "cn.colablog.mybatis.mapper")
public class MybatisApplication {
 public static void main(String[] args) {
  SpringApplication.run(MybatisApplication.class, args);
 }
}
Mapper 맵\#
UserMapper 인터페이스\#
Mapper 패키지 cn.colablog.my batis.mapper 디 렉 터 리 에 UserMapper 인 터 페 이 스 를 추가 합 니 다.

@Mapper
public interface UserMapper {
 List<User> getAllUser();
}
UserMapper.xml#
Copy
<?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">
<mapper namespace="com.colablog.mybatis.mapper.UserMapper">
 <select id="getAllUser" resultType="com.colablog.mybatis.bean.User">
  select * from user
 </select>
</mapper>
저장 방식 은 세 가지 가 있 습 니 다.
모드 1(기본 값)
SpringBoot 는 기본적으로 Mapper.xml 을 찾 는 것 은 resources 디 렉 터 리 에 있 습 니 다.예 를 들 어 User 류 를 매 핑 하 는 경 로 는 자바 디 렉 터 리 에 있 는 cn.colablog.my batis.mapper 입 니 다.
그러면 UserMapper.xml 는 resources 디 렉 터 리 에 있 는 cn.colablog.my batis.mapper 가 필요 합 니 다.
메모:IDEA 개발 도 구 를 사용한다 면 resource 에 디 렉 터 리 를 추가 할 수 없습니다.

이렇게 IDEA 를 추가 하면 cn.colablog.my batis.mapper 라 는 디 렉 터 리 만 추가 할 수 있 습 니 다.따라서 디 렉 터 리 마다 순서대로 추가 해 야 합 니 다.저장 위 치 는 다음 과 같 습 니 다.

방식 2
properties 파일 에 저장 경 로 를 설정 합 니 다:mybatis.mapper-locations=classpath:/mapper/*.xml저장 위 치 는 다음 과 같 습 니 다.

방 식 삼
pom.xml 에 resource 를 설정 하려 면 자바 디 렉 터 리 에 있 는 xml 파일 을 불 러 와 야 합 니 다:

 <build>
  <resources>
   <resource>
    <directory>src/main/java</directory>
    <includes>
     <include>**/*.xml</include>
    </includes>
   </resource>
   <resource>
    <directory>src/main/resources</directory>
   </resource>
  </resources>
  ...
 </build>
이렇게 하면 UserMapper 인터페이스 와 같은 디 렉 터 리 에 저장 할 수 있 습 니 다.위 치 는 다음 과 같 습 니 다.

좋은 웹페이지 즐겨찾기