SpringBoot 가 jdbc 와 my batis 를 통합 하 는 방법
8053 단어 SpringBoot통합jdbcmybatis
다음은 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 인터페이스 와 같은 디 렉 터 리 에 저장 할 수 있 습 니 다.위 치 는 다음 과 같 습 니 다.이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
【Java・SpringBoot・Thymeleaf】 에러 메세지를 구현(SpringBoot 어플리케이션 실천편 3)로그인하여 사용자 목록을 표시하는 응용 프로그램을 만들고, Spring에서의 개발에 대해 공부하겠습니다 🌟 마지막 데이터 바인딩에 계속 바인딩 실패 시 오류 메시지를 구현합니다. 마지막 기사🌟 src/main/res...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.