Tech/Spring

[Spring Data JPA] 스프링 테이블, 컬럼명 생성 전략

0m1n 2023. 3. 22. 19:00
728x90
반응형

이 포스트는 김영한님의 스프링부트와 JPA 활용1 강의 내용 기반으로 요약하였다.

테이블, 컬럼명 생성 전략

  • 스프링 부트에서 하이버네이트 기본 매핑 전략을 변경해서 실제 테이블 필드명은 다름
  • 하이버네이트 기존 구현: 엔티티의 필드명을 그대로 테이블의 컬럼명으로 사용 ( SpringPhysicalNamingStrategy )
  • 스프링 부트 신규 설정 (엔티티(필드) 테이블(컬럼))

자동으로 변환됨.

  1. 카멜 케이스 → 언더스코어(memberPoint → member_point)
  2. .(점) → _(언더스코어)
  3. 대문자 → 소문자

적용 2 단계

논리명 생성

  • 명시적으로 컬럼, 테이블명을 직접 적지 않으면 ImplicitNamingStrategy 사용
  • spring.jpa.hibernate.naming.implicit-strategy : 테이블이나, 컬럼명을 명시하지 않을 때 논리명

적용 물리명 적용

  • spring.jpa.hibernate.naming.physical-strategy : 모든 논리명에 적용됨, 실제 테이블에 적용 (username usernm 등으로 회사 룰로 바꿀 수 있음)
728x90
반응형