개인프로젝트 일지_3 | MySQL, JPA 스프링 부트 연동 테스트하는 법

2024. 6. 5. 16:51· 프로젝트일지
목차
  1. 1. application.properties 설정
  2. 2. Test 디렉토리 경로
  3. 3. 코드
  4. 4. 결과
728x90

1. application.properties 설정

spring.application.name=planBuddy
server.port=8000

# MySQL Database configuration
spring.datasource.url=jdbc:mysql://<엔드포인트>:<포트번호>/<데이터베이스이름>
spring.datasource.username=<마스터 이름>
spring.datasource.password=<마스터 비밀번호>
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

# JPA configuration
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQLDialect

✔️MySQL Database를 연동한다.

 

✔️spring.jpa.hibernate.ddl-auto=update

-> 애플리케이션 실행 시 JPA가 @Entity 어노테이션이 붙은 클래스에 데이터베이스 스키마를 생성하거나 업데이트한다.

 

2. Test 디렉토리 경로

Project_1st 하위에 test 디렉토리를 생성하고

test하위에 entity, repository 디렉토리를 만들었다.

 

3. 코드

✅User

package Project_1st.test.entity;

import jakarta.persistence.Entity;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.GenerationType;
import jakarta.persistence.Id;
import lombok.Getter;
import lombok.Setter;

@Entity
@Getter
@Setter
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;

    // Constructors
    public User() {}

    public User(String name) {
        this.name = name;
    }

}

@Entity가 붙은 User클래스는 데이터베이스 테이블로 매핑된다.

 

✅UserRepository

package Project_1st.test.repository;

import Project_1st.test.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;

public interface UserRepository extends JpaRepository<User, Long> {
}

 

✅TestApplication

package Project_1st.test;

import Project_1st.test.entity.User;
import Project_1st.test.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class TestApplication implements CommandLineRunner {

    @Autowired
    private UserRepository userRepository;

    public static void main(String[] args) {
        SpringApplication.run(TestApplication.class, args);
    }
    @Override
    public void run(String... args) throws Exception {
        // 데이터 삽입
        User user = new User("ururuwave");
        userRepository.save(user);

        // 데이터 조회
        userRepository.findAll().forEach(System.out::println);
    }
}

✔️클래스는 실행 시 CommandLineRunner를 구현하여 User 엔티티 객체를 저장하고 조회한다.

 

4. 결과

워커벤치에서 확인해보면 id는 자동으로 숫자가 증가되어 저장되고

TestApplication 클래스에 "ururuwave"로 데이터를 삽입한대로 테이블에 update된 것을 확인할 수 있다.

 

728x90

'프로젝트일지' 카테고리의 다른 글

개인프로젝트 일지_6 | 프론트엔드와 백엔드 연동하기  (0) 2024.06.05
개인 프로젝트 일지_5 | MongoDB , 스프링 부트 연동 및 테스트  (0) 2024.06.05
개인프로젝트 일지_4 | MongoDB Atlas 클러스터 생성 및 설정  (0) 2024.06.05
개인 프로젝트 일지_2 | AWS RDS mysql 설정  (0) 2024.06.05
개인 프로젝트 일지_1 | 프로젝트 기획 및 설계  (0) 2024.06.04
  1. 1. application.properties 설정
  2. 2. Test 디렉토리 경로
  3. 3. 코드
  4. 4. 결과
'프로젝트일지' 카테고리의 다른 글
  • 개인 프로젝트 일지_5 | MongoDB , 스프링 부트 연동 및 테스트
  • 개인프로젝트 일지_4 | MongoDB Atlas 클러스터 생성 및 설정
  • 개인 프로젝트 일지_2 | AWS RDS mysql 설정
  • 개인 프로젝트 일지_1 | 프로젝트 기획 및 설계
백엔드 개발자 - 젤리곰
백엔드 개발자 - 젤리곰
오늘도 배움이 있는 하루가 되길 바라는 개발자
백엔드 개발자 - 젤리곰
backend-gummyBear
백엔드 개발자 - 젤리곰
전체
오늘
어제
  • 분류 전체보기 (144)
    • 인프런 김영한 강의 정리 (60)
      • 스프링 핵심원리 기본편 (12)
      • 모든 개발자를 위한 HTTP 웹 기본 지식 (10)
      • 스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술 (3)
      • 자바 ORM 표준 JPA 프로그래밍 기본편 (28)
      • 실전! Querydsl (6)
    • Spring (2)
    • 프로젝트일지 (6)
    • 프로그래밍 언어 (20)
      • Java (17)
      • JavaScript (3)
      • Python (0)
    • 데이터베이스 (4)
      • Oracle (2)
      • ORM (1)
      • SQL 튜닝 (1)
    • 형상관리 (1)
      • Git (0)
    • 알고리즘&자료구조 (34)
      • Algorithm (31)
      • Data Structure (1)
    • CS지식 (4)
    • Cloud (5)
    • 일기 (7)
      • 공부 일기 (3)
      • 독서 일기 (2)
      • 마음 일기 (2)

블로그 메뉴

  • 홈
  • 태그

공지사항

인기 글

태그

  • 커스텀annotation
  • 데이터베이스정규화
  • SublimeText단축키
  • jquery와javascript
  • 클라이언트서버통신
  • LeetCode200번
  • 프론트엔드역사
  • 객체지향방법론
  • 힙자료구조
  • LeetCode17번
  • dfs알고리즘
  • ORM프레임워크
  • 인프콘
  • #{}와${}의차이
  • 객체지향의사실과오해
  • 다운캐스팅
  • 업캐스팅
  • 프론트엔드개발자업무
  • 스프링컨텍스트
  • 인터페이스

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.2
백엔드 개발자 - 젤리곰
개인프로젝트 일지_3 | MySQL, JPA 스프링 부트 연동 테스트하는 법
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.