inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바와 스프링 부트로 생애 최초 서버 만들기, 누구나 쉽게 개발부터 배포까지! [서버 개발 올인원 패키지]

34강. JPA 연관관계에 대한 추가적인 기능들

DB 테이블간 연결에 대한 질문입니다.

해결된 질문

418

alice

작성한 질문수 55

2

안녕하세요 태현님. 두가지 질문이 있습니다.

1. 지금까지(34강) 강의를 따라 하고 MySQL 워크벤치에서 ERD를 확인해 보면

테이블 간에 PK - FK로 연결이 안 되어있는데요

연결을 안 해주어도 괜찮은 이유가 뭔지 궁금합니다.

제가 NestJS나 Express.js 로 백엔드를 만들었을 때는
TypeORM, Prisma, Sequelize 같은 ORM을 이용했었는데

그때는 코드단에서 테이블 간에 연결 처리 (PK - FK로 연결)을 해주면

데이터베이스에서 확인을 해봤을 때
YS.png

이런 식으로 연결이 된 것을 확인할 수 있었거든요..

혹시 제가 뭔가 잘못 알고 있는 걸까요?
굳이 DB에서 실제로 연결을 안 해주어도 괜찮은 건가요??

아니면 스프링 + JPA 조합의 특성인가요??


2. 그리고 MySQL 워크벤치에서

create table user_loan_history (

  id bigint auto_increment,

  user_id bigint,

  book_name varchar(255),

  is_return tinyint(1),

  primary key (id)

);

이렇게 DB create 문을 작성해서 실행 시키지 않아도
서버를 실행시킬 때 자동으로 로컬 DB에 테이블을 생성해 주도록 하는 설정이 있는지 궁금합니다.

 

java spring aws mysql spring-boot jpa

답변 1

2

최태현

안녕하세요 alice님! 정말 좋은 질문 감사드립니다~ 😊

 

하나씩 답변드려보면,

 

[1. FK를 사용하지 않은 이유]

말씀해주신 것처럼 FK를 사용하면, 서로 다른 두 개의 테이블이 연결되어 있다는 것을 GUI 상으로 보다 더 확실하게 확인할 수 있습니다.

다만, JS를 사용해 서버를 구성하건, Java를 사용해 서버를 구성하건, 개인적으로 실무에서 FK를 잘 사용하지는 않았습니다. (특정 언어나 프레임워크의 특이 취향(?)은 아니라고 봐주시면 됩니다 ㅎㅎ)

 

그 이유는 간단히 말씀드려 편의성과 성능 때문입니다!!

아래 두 글을 읽어보시면 도움 되시지 않을까 싶습니다 ㅎㅎㅎ

 

[2. 로컬 DB 테이블 자동 생성 기능]

application.yml 에 존재하는 ddl-auto 옵션을 보시면 됩니다!

섹션 4 - 24강을 보시면 자세히 설명이 나와 있습니다! 😊

 

  • ddl-auto 는 스프링이 시작할 때 DB에 있는 테이블을 어떻게 처리할지에 대한 옵션이다.

    • create : 기존 테이블이 있다면 삭제 후 다시 생성한다.

    • create-drop : 스프링이 종료될 때 테이블을 삭제한다.

    • update : 객체와 테이블이 다른 부분만 변경한다.

    • validate : 객체와 테이블이 동일한지 확인한다.

    • none : 별다른 조치를 하지 않는다.

여기서 create 또는 create-drop 또는 update를 사용하시면 테이블 생성을 자동화하실 수 있을 겁니다!

답변이 도움이 되었으면 좋겠습니다~ 감사합니다!! 🙇🙇

패키지 구분에 대해 궁금한게 있습니다

0

25

2

리액트 관련 질문이 있습니다.

0

65

2

스프링부트 버전

0

76

2

7강 강의를 들으려고 했는데 오류가 나서 서버가 안 켜지는거 같아요.

0

59

2

33강. UserLoanHistory의 관계성에 대한 질문

1

56

2

Java JDK 버전 문의의 건

0

135

2

ec2 에서 Linux버전이 달라져서 설치가 안되는것 같은데 자료 최신화좀 해주세요.

0

90

3

h2 console 접속했을 테이블 질문

1

67

1

ec2 서버에서 스프링 실행도 되고 인바운드 설정까지 했는데 index.html 안됨

0

80

2

15강. updateUser() 질문

0

57

2

깃허브 질

0

84

2

여기까지 다 끝냈다고 하셨는데

0

79

2

왜안될까요

0

72

2

MySQL 창이안ㄴ뜹니다

0

59

2

포스트맨

0

52

1

spring 개념적인 질문

0

72

2

인텔리제이 샘플코드 실행 안됨 오류

0

142

2

aws 배포할때 .env 파일에 저장한 환경변수에 관하여 여쭤볼게 있습니다

0

87

1

마이그레이션 오류입니다.

0

175

3

Whitelabel Error Page 오류가 났습니다.

0

166

2

안녕하십니까! 오류가 났습니다.. 도와주세요 ㅜㅜ

1

94

3

궁금한게 있습니다.

0

61

2

DTO 관련

0

70

2

궁금한게 있습니다!

0

69

2