MySQL의 테이블 자동 생성 시에 대해서
본 강의 내용대로,
Member 클래스
@Id @GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "MEMBER_ID")
private Long id;
persistence.xml
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
로 설정하면 jpa 실행하면서 생성되는 테이블 컬럼에 'auto_increment'가 설정된 것을 확인했습니다.
그런데 Member 클래스의 @GeneratedValue 속성만 기본 값(GenerationType.AUTO)으로 설정하면 auto_increment가 설정되지 않고, 마치 GenerationType.TABLE으로 설정한 것처럼 시퀀스용(=키 생성 전용) 테이블이 별도로 생성되는 것을 확인했습니다.
제가 궁금한 것은, @GeneratedValue 전략을 설정할 때, persistence.xml의 DB 방언 설정에 따라 같이 병행해야하나요?
답변 1
2
안녕하세요. 덩더러러쿨님
AUTO는 데이터베이스 방언에 따라서 각각 다르게 전략이 설정됩니다.
그래서 딱 정리해드리면, 실무에서는 AUTO를 사용하지 말고, 전략을 지정하는게 좋습니다.
감사합니다.
실무 조언 관련 질문입니다.
0
39
1
H2데이터베이스 파일 생성
0
48
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
49
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
46
1
JPQL 메소드와 락
0
48
1
Delivery @OneToOne
0
55
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
85
2
UnsupportedOperationException 발생
0
80
3
H2 Database 연결이 안됩니다.
0
87
2
연관관계 매핑 질문드립니다.
0
78
2
h2데이터베이스 실행오류
0
103
2
persistence.xml
0
101
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
76
1
영속성 컨텍스트
0
61
1
JPA 프록시
0
87
1
Native Query와 MyBatis
0
62
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
81
1
임베디드 타입 예시 코드 관련 질문
0
110
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
89
3
인텔리제이 패키지 커서 단축키 질문
0
104
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
134
1
양방향 연관관계 시 연관관계 주인을 설정하는 이유
0
67
1
임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.
0
95
1
데이터베이스가 초기화되는 것 같아요
1
173
2





