찾다
Javajava지도 시간MyBatis를 사용하여 Spring Boot에서 데이터 액세스 및 지속성 구현

Spring Boot는 개발자가 웹 애플리케이션을 빠르게 구축하는 데 도움이 되는 신속한 개발 프레임워크입니다. MyBatis는 Java와 데이터베이스 간의 데이터 액세스 및 지속성을 단순화할 수 있는 탁월한 ORM 프레임워크입니다. 이 기사에서는 MyBatis를 사용하여 Spring Boot에서 데이터 액세스 및 지속성을 구현하는 방법을 소개합니다.

1. Spring Boot는 MyBatis를 통합합니다

  1. 종속성 추가

pom.xml 파일에 MyBatis 및 MySQL 종속성을 추가합니다.

<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.1</version>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.42</version>
</dependency>

여기에서는 mybatis-spring-boot-starter를 사용하여 MyBatis를 통합합니다.

  1. 데이터 소스 구성

application.properties에 데이터베이스 연결 속성을 추가하세요.

spring.datasource.url=jdbc:mysql://localhost:3306/test?useSSL=false
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driverClassName=com.mysql.jdbc.Driver

여기에서는 MySQL 데이터베이스를 사용하고 비밀번호 123456의 루트 계정을 사용하여 연결합니다.

  1. MyBatis 구성

Spring Boot는 기본적으로 매퍼 경로를 자동으로 검색합니다. application.properties에서 매퍼 경로만 구성하면 됩니다.

mybatis.mapper-locations=classpath:mapper/*.xml

이 구성은 매퍼 파일이 프로젝트의 매퍼 폴더에 있음을 나타냅니다. 클래스 경로.

위 구성을 완료한 후 Spring Boot는 MyBatis 통합을 완료했습니다.

2. 엔터티 클래스 및 매퍼 작성

  1. 엔티티 클래스 작성

데이터베이스에서 사용자 테이블을 나타내는 사용자 클래스 정의:

public class User {
    private Long id;
    private String name;
    private Integer age;
    // 省略getter和setter方法
}
  1. 매퍼 작성

사용자 테이블 추가 정의를 위한 UserMapper 인터페이스 정의, 삭제, 수정 및 쿼리 작업:

public interface UserMapper {
    void saveUser(User user);
    void updateUser(User user);
    void deleteUser(Long id);
    User findUserById(Long id);
    List<User> findAllUsers();
}

여기에서는 모든 사용자를 추가, 삭제, 수정 및 쿼리하는 방법을 정의합니다.

3. Mapper.xml 작성

다음으로 UserMapper에 정의된 작업을 구현하기 위해 UserMapper.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">
<mapper namespace="com.example.demo.mapper.UserMapper">
    <insert id="saveUser" parameterType="com.example.demo.entity.User">
        insert into user(name, age) values (#{name}, #{age})
    </insert>

    <update id="updateUser" parameterType="com.example.demo.entity.User">
        update user set name = #{name}, age = #{age} where id = #{id}
    </update>

    <delete id="deleteUser" parameterType="java.lang.Long">
        delete from user where id = #{id}
    </delete>

    <select id="findUserById" parameterType="java.lang.Long"
            resultType="com.example.demo.entity.User">
        select * from user where id = #{id}
    </select>

    <select id="findAllUsers" resultType="com.example.demo.entity.User">
        select * from user
    </select>
</mapper>

이 파일에서는 UserMapper에 정의된 모든 메서드를 구현합니다. 여기서 매개변수 유형은 매개변수를 나타냅니다. Type, resultType은 반환 값 유형을 나타냅니다.

4. 서비스 클래스 및 컨트롤러 작성

  1. 서비스 클래스 작성

User 테이블의 작업을 캡슐화하는 UserService 클래스 정의:

@Service
public class UserService {
    @Autowired
    private UserMapper userMapper;

    public void saveUser(User user) {
        userMapper.saveUser(user);
    }

    public void updateUser(User user) {
        userMapper.updateUser(user);
    }

    public void deleteUser(Long id) {
        userMapper.deleteUser(id);
    }

    public User findUserById(Long id) {
        return userMapper.findUserById(id);
    }

    public List<User> findAllUsers() {
        return userMapper.findAllUsers();
    }
}

이 클래스에서는 @Autowired 주석을 사용하여 UserMapper를 삽입합니다. 즉, UserMapper에 정의된 메소드를 사용할 수 있습니다.

  1. 컨트롤러 작성

UserController 클래스를 정의하여 사용자에 대한 추가, 삭제, 수정 및 쿼리 작업을 구현합니다.

@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private UserService userService;

    @PostMapping("/")
    public String saveUser(@RequestBody User user) {
        userService.saveUser(user);
        return "success";
    }

    @PutMapping("/")
    public String updateUser(@RequestBody User user) {
        userService.updateUser(user);
        return "success";
    }

    @DeleteMapping("/{id}")
    public String deleteUser(@PathVariable Long id) {
        userService.deleteUser(id);
        return "success";
    }

    @GetMapping("/{id}")
    public User getUserById(@PathVariable Long id) {
        return userService.findUserById(id);
    }

    @GetMapping("/")
    public List<User> findAllUsers() {
        return userService.findAllUsers();
    }
}

이 클래스에서는 @RestController 주석을 사용하여 현재 클래스가 컨트롤러임을 나타냅니다. @RequestMapping 주석을 사용하여 액세스 경로를 지정합니다. 동시에 UserService는 @Autowired 어노테이션을 사용하여 주입됩니다. 즉, UserService에 정의된 메소드를 사용할 수 있습니다.

5. 테스트

이제 전체 프로젝트의 구성과 코딩이 완료되었습니다. 다음으로 Postman과 같은 도구를 사용하여 컨트롤러에 정의된 API를 테스트할 수 있습니다.

POST 요청을 사용하여 사용자 정보 저장, 요청 본문:

{
    "name": "张三",
    "age": 18
}

PUT 요청을 사용하여 사용자 정보 업데이트, 요청 본문:

{
    "id": 1,
    "name": "李四",
    "age": 20
}

DELETE 요청을 사용하여 사용자 정보 삭제, URL:

http://localhost:8080/user/1

사용 사용자 정보를 얻기 위한 GET 요청, URL은

http://localhost:8080/user/1

모든 사용자 정보를 얻으려면 GET 요청을 사용하세요. URL은

http://localhost:8080/user/

6. 요약

이 기사에서는 MyBatis를 사용하여 Spring에서 데이터 액세스 및 지속성을 달성하는 방법을 소개합니다. 부팅하고 간단한 예를 사용하여 전체 프로세스를 설명합니다. MyBatis는 Java 프로그램의 데이터베이스 작업을 보다 효율적이고 간결하게 만들 수 있습니다. Spring Boot에서 데이터베이스 작업을 구현해야 하는 경우 MyBatis 사용을 고려할 수 있습니다.

위 내용은 MyBatis를 사용하여 Spring Boot에서 데이터 액세스 및 지속성 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?Mar 17, 2025 pm 05:46 PM

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:45 PM

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?Mar 17, 2025 pm 05:44 PM

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:43 PM

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Mar 17, 2025 pm 05:35 PM

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

See all articles

핫 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. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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