Java java지도 시간 Spring Boot와 MyBatis Plus를 기반으로 ORM 매핑 구현

Spring Boot와 MyBatis Plus를 기반으로 ORM 매핑 구현

Jun 22, 2023 pm 09:27 PM
spring boot Orm 매핑 mybatis plus

Java 웹 애플리케이션 개발 과정에서 ORM(Object-Relational Mapping) 매핑 기술을 사용하여 데이터베이스의 관계형 데이터를 Java 객체에 매핑함으로써 개발자가 데이터에 편리하게 접근하고 조작할 수 있습니다. 현재 가장 널리 사용되는 Java 웹 개발 프레임워크 중 하나인 Spring Boot는 MyBatis를 통합할 수 있는 방법을 제공했으며, MyBatis Plus는 MyBatis를 기반으로 확장된 ORM 프레임워크입니다. 이 기사에서는 Spring Boot와 MyBatis Plus를 사용하여 ORM 매핑을 구현하는 방법을 소개합니다.

1. Spring Boot는 MyBatis Plus를 통합합니다.
Spring Boot에서 MyBatis Plus를 사용하는 것은 매우 간단합니다. MyBatis Plus의 종속성을 Maven에 추가하기만 하면 됩니다.

<dependency>
  <groupId>com.baomidou</groupId>
  <artifactId>mybatis-plus-boot-starter</artifactId>
  <version>3.4.2</version>
</dependency>
로그인 후 복사

동시에 MyBatis Plus 관련 매개 변수를 application.properties 또는 application.yml에 아래와 같이 구성합니다.

#数据库配置
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis_plus?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=123456
#MyBatis Plus配置
mybatis.configuration.cache-enabled=false
mybatis.mapper-locations=classpath:mapper/*.xml
로그인 후 복사

그 중 드라이버 클래스 이름, URL, 사용자 이름 및 비밀번호는 데이터베이스 관련 구성이며, mapper-locations는 MyBatis Plus의 SQL 매핑 구성 파일이 위치한 경로입니다.

2. 엔터티 클래스와 매퍼 인터페이스 정의
MyBatis와 마찬가지로 MyBatis Plus를 사용하려면 엔터티 클래스와 매퍼 인터페이스도 정의해야 합니다. 다음은 해당 엔터티 클래스와 매퍼 인터페이스를 정의하기 위한 예로 간단한 사용자 테이블을 사용합니다.

  1. 엔티티 클래스 정의
@Getter
@Setter
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class User {

    private Integer id;
    private String name;
    private Integer age;
    private String email;
    private Integer gender;
    private LocalDateTime createTime;
    private LocalDateTime updateTime;

}
로그인 후 복사

@Getter, @Setter 및 @Builder 주석을 사용하면 코드를 단순화할 수 있으며, @NoArgsConstructor 및 @AllArgsConstructor는 매개변수 없는 생성자와 전체 매개변수 생성자를 생성하는 데 사용됩니다.

  1. 매퍼 인터페이스 정의
public interface UserMapper extends BaseMapper<User> {
}
로그인 후 복사

MyBatis Plus에서 제공하는 BaseMapper가 여기에 사용되어 지루한 SQL 작업을 많이 줄일 수 있습니다.

3. 데이터베이스 작업에 MyBatis Plus를 사용하세요
Mapper 인터페이스를 정의한 후 데이터베이스 작업에 MyBatis Plus를 사용할 수 있습니다.

  1. Insert data
User user = User.builder()
        .name("test")
        .age(20)
        .email("test@test.com")
        .gender(1)
        .createTime(LocalDateTime.now())
        .updateTime(LocalDateTime.now())
        .build();
int count = userMapper.insert(user);
로그인 후 복사

데이터를 삽입할 때 Mapper 인터페이스에서 제공하는 insert 메소드를 직접 사용할 수 있으며, 마이바티스 플러스는 자동으로 엔터티 클래스의 속성을 데이터베이스의 해당 열에 매핑합니다.

  1. 데이터 쿼리
List<User> userList = userMapper.selectList(null);
로그인 후 복사

데이터 쿼리 시 Mapper 인터페이스에서 제공하는 selectList 메서드를 직접 사용하고 null 또는 빈 QueryWrapper 개체를 전달하여 모든 데이터를 쿼리할 수 있습니다. 또한 아래와 같이 MyBatis Plus에서 제공하는 람다 식과 체인 연산을 사용하여 보다 복잡한 쿼리를 수행할 수도 있습니다.

QueryWrapper<User> wrapper = Wrappers.<User>lambdaQuery()
        .eq(User::getGender, 1)
        .ge(User::getAge, 20)
        .orderByDesc(User::getCreateTime);
List<User> userList = userMapper.selectList(wrapper);
로그인 후 복사

위 코드에서 QueryWrapper는 Wrappers.lambdaQuery() 개체를 사용하여 정의됩니다. .eq, .ge 및 .orderByDesc 체인 작업을 통해 쿼리 조건 및 정렬 규칙을 구축합니다.

  1. Update data
User user = userMapper.selectById(id);
user.setAge(30);
int count = userMapper.updateById(user);
로그인 후 복사

데이터를 업데이트할 때 먼저 selectById를 통해 업데이트가 필요한 데이터를 쿼리한 후 업데이트가 필요한 속성을 수정하고 updateById를 이용해 수정된 데이터를 데이터베이스에 업데이트할 수 있습니다.

  1. 데이터 삭제
int count = userMapper.deleteById(id);
로그인 후 복사

마지막으로 데이터를 삭제할 때는 Mapper 인터페이스에서 제공하는 deleteById 메소드를 호출하면 됩니다.

4. 결론
이 글에서는 Spring Boot와 MyBatis Plus를 사용하여 ORM 매핑을 구현하는 방법을 소개하고, 간단한 구성과 코드를 통해 데이터베이스 작업을 수행할 수 있습니다. MyBatis Plus는 MyBatis의 확장 프레임워크로서 코드의 가독성과 유지 관리성을 향상시키면서 개발자의 작업량을 크게 단순화할 수 있습니다. 지면의 제약으로 인해 이 글에서는 MyBatis Plus의 기본적인 사용법만 소개합니다. 보다 고급 기능에 대해서는 공식 문서를 참고하시기 바랍니다.

위 내용은 Spring Boot와 MyBatis Plus를 기반으로 ORM 매핑 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Spring Boot+MyBatis+Atomikos+MySQL(소스 코드 포함) Spring Boot+MyBatis+Atomikos+MySQL(소스 코드 포함) Aug 15, 2023 pm 04:12 PM

실제 프로젝트에서는 분산 트랜잭션을 피하려고 노력합니다. 그러나 때로는 일부 서비스 분할을 수행해야 하므로 분산 트랜잭션 문제가 발생할 수 있습니다. 동시에 면접 시 시장에서도 분산 거래에 대한 질문을 하게 되는데, 이 사례를 가지고 연습도 할 수 있고, 면접에서는 123에 대해서도 이야기를 나눌 수 있습니다.

Spring Boot를 통해 다국어 지원 및 국제 애플리케이션 달성 Spring Boot를 통해 다국어 지원 및 국제 애플리케이션 달성 Jun 23, 2023 am 09:09 AM

세계화가 발전함에 따라 점점 더 많은 웹사이트와 애플리케이션이 다국어 지원과 국제화 기능을 제공해야 합니다. 개발자에게 이러한 기능을 구현하는 것은 언어 번역, 날짜, 시간, 통화 형식 등 여러 측면을 고려해야 하기 때문에 쉬운 작업이 아닙니다. 그러나 SpringBoot 프레임워크를 사용하면 다국어 지원과 국제 애플리케이션을 쉽게 구현할 수 있습니다. 먼저 SpringBoot에서 제공하는 LocaleResolver 인터페이스를 이해해보자. 위치

Spring Boot를 사용하여 빅 데이터 처리 애플리케이션을 구축하는 방법 Spring Boot를 사용하여 빅 데이터 처리 애플리케이션을 구축하는 방법 Jun 23, 2023 am 09:07 AM

빅데이터 시대가 도래하면서 빅데이터의 가치를 이해하고 이를 비즈니스에 적용하는 기업이 점점 늘어나고 있습니다. 이에 따른 문제는 이러한 대규모 데이터 흐름을 처리하는 방법입니다. 이 경우 빅데이터 처리 애플리케이션은 모든 기업이 고려해야 할 사항이 되었습니다. 개발자에게는 SpringBoot를 사용하여 효율적인 빅데이터 처리 애플리케이션을 구축하는 방법도 매우 중요한 문제입니다. SpringBoot는 다음을 허용하는 매우 인기 있는 Java 프레임워크입니다.

Spring Boot와 MyBatis Plus를 기반으로 ORM 매핑 구현 Spring Boot와 MyBatis Plus를 기반으로 ORM 매핑 구현 Jun 22, 2023 pm 09:27 PM

Java 웹 애플리케이션 개발 과정에서 ORM(Object-RelationalMapping) 매핑 기술을 사용하여 데이터베이스의 관계형 데이터를 Java 객체로 매핑함으로써 개발자가 데이터에 접근하고 조작하는 것을 편리하게 만듭니다. 가장 널리 사용되는 Java 웹 개발 프레임워크 중 하나인 SpringBoot는 MyBatis를 통합하는 방법을 제공했으며, MyBatisPlus는 MyBatis를 기반으로 확장된 ORM 프레임워크입니다.

Spring Boot와 NoSQL 데이터베이스 통합 및 사용 Spring Boot와 NoSQL 데이터베이스 통합 및 사용 Jun 22, 2023 pm 10:34 PM

인터넷의 발달로 인해 빅데이터 분석과 실시간 정보처리는 기업의 중요한 요구사항이 되었습니다. 이러한 요구 사항을 충족하기 위해 기존 관계형 데이터베이스는 더 이상 비즈니스 및 기술 개발 요구 사항을 충족하지 않습니다. 대신 NoSQL 데이터베이스를 사용하는 것이 중요한 옵션이 되었습니다. 이 기사에서는 NoSQL 데이터베이스와 통합된 SpringBoot를 사용하여 최신 애플리케이션을 개발하고 배포하는 방법에 대해 설명합니다. NoSQL 데이터베이스란 무엇입니까? NoSQL은 SQL이 아닙니다.

Spring Boot와 Apache ServiceMix를 사용하여 ESB 시스템 구축 Spring Boot와 Apache ServiceMix를 사용하여 ESB 시스템 구축 Jun 22, 2023 pm 12:30 PM

현대 기업이 다양한 서로 다른 애플리케이션과 시스템에 점점 더 많이 의존함에 따라 엔터프라이즈 통합이 더욱 중요해지고 있습니다. ESB(Enterprise Service Bus)는 다양한 시스템과 애플리케이션을 함께 연결하여 공통 데이터 교환 및 메시지 라우팅 서비스를 제공하여 엔터프라이즈 수준 애플리케이션 통합을 달성하는 통합 아키텍처 모델입니다. SpringBoot와 ApacheServiceMix를 이용하면 ESB 시스템을 쉽게 구축할 수 있다. 이 글에서는 이를 구현하는 방법을 소개한다. 스프링부트와 A

Spring Boot 및 JavaFX를 사용하여 데스크톱 애플리케이션 구축 Spring Boot 및 JavaFX를 사용하여 데스크톱 애플리케이션 구축 Jun 22, 2023 am 10:55 AM

기술이 계속 발전함에 따라 이제 다양한 기술을 사용하여 데스크톱 애플리케이션을 구축할 수 있습니다. SpringBoot와 JavaFX는 현재 가장 인기 있는 선택 중 하나입니다. 이 기사에서는 이 두 프레임워크를 사용하여 기능이 풍부한 데스크톱 애플리케이션을 구축하는 방법에 중점을 둘 것입니다. 1. SpringBoot 및 JavaFX 소개SpringBoot는 Spring 프레임워크를 기반으로 하는 신속한 개발 프레임워크입니다. 개발자가 웹 애플리케이션을 신속하게 구축하는 동시에 일련의 기능을 제공하는 데 도움이 됩니다.

Spring Boot는 MySQL 읽기-쓰기 분리 기술을 구현합니다. Spring Boot는 MySQL 읽기-쓰기 분리 기술을 구현합니다. Aug 15, 2023 pm 04:52 PM

읽기-쓰기 분리를 달성하는 방법, Spring Boot 프로젝트, 데이터베이스는 MySQL이고 지속성 레이어는 MyBatis를 사용합니다.

See all articles