테이블 생성 순서중 id 값 ( Pk)
테이블 ddl create 로 자동 생성할때
강사님은 id 값 생성은 무조건 순서 1번째 컬럼으로 가는데
저는 그거 상관없이 무조건 알파벳 순이네요 pk포함
버전에 따른 문제인건가요?
방법은 없을까요
아래는 제 버전입니다.
<!-- JPA 하이버네이트 -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>6.2.7.Final</version>
</dependency>
<!-- H2 데이터베이스 -->
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>1.4.200</version>
</dependency>
@Entity
public class Member {
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE)
private Long id;
@Column(name = "name", length = 30, nullable = false)
private String username;
@Column
private int age;

이렇게 했을때 테이블 create 결과는 이렇구요,
근데 정말 신기한건 만약 age 를 int 에서 String 타입으로 바꾸면 뒤로 밀리네요
이게 타입별로 먼저 정렬하고 그 뒤에 알파벳인거같기도하고
왜 그런걸까요?
뭐 솔직히 실무에서는 중요한 내용은 아닌거 같은데
강사님 버전 타입이랑 달라서 궁금합니다.
그리고 테이블 순서에대한 내용은 hibernate 문서를 보면 되는걸까요?
문서를보고 직접 확인해보고싶네용
답변 1
0
안녕하세요, 인프런 AI 인턴이에요. 테이블의 id 값 생성 순서와 관련해서는 JPA 구현체마다 다를 수 있습니다. 그러나 일반적으로 JPA에서는 id 값의 생성 순서를 제어하기 위해 @GeneratedValue 어노테이션을 사용합니다.
현재 사용하고 계신 Hibernate 버전 6.2.7.Final은 Hibernate 6 버전으로, 이전 버전들과 달리 id 값의 순서를 컬럼의 선언 순서로 결정하는 방식으로 동작합니다. 따라서 Member 클래스에서 id 컬럼을 가장 먼저 선언했기 때문에 id 값을 가지는 컬럼이 테이블의 첫 번째 컬럼으로 생성되게 됩니다.
또한, age 컬럼을 int에서 String으로 변경했을 때 컬럼의 위치가 변경되는 현상이 있으신데요, 이는 데이터베이스에서 문자열 타입보다 숫자 타입을 먼저 정렬하도록 구현된 것입니다. 따라서 String 타입으로 변경하면 age 컬럼의 위치가 id 컬럼 뒤로 밀리게 됩니다.
이러한 동작은 Hibernate 6 버전에서의 특징이므로, 실무에서 중요한 내용은 아니라고 생각하셔도 됩니다. 다만, Hibernate 버전에 따라서 동작 방식이 다를 수 있기 때문에 다른 버전에서는 다르게 동작할 수도 있습니다.
더 자세한 내용은 Hibernate 공식 문서나 커뮤니티에서 해당 버전의 변경 내역을 확인해보시면 도움이 될 것입니다. 혹시 다른 질문이 있으시면 언제든지 물어보세요. 좋은 하루되세요!
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
16
2
inheritance startegy 선택시 고려사항
0
21
1
Entity 동등성 비교
0
18
1
실무 조언 관련 질문입니다.
0
44
1
H2데이터베이스 파일 생성
0
56
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
52
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
51
1
JPQL 메소드와 락
0
55
1
Delivery @OneToOne
0
60
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
92
2
UnsupportedOperationException 발생
0
85
3
H2 Database 연결이 안됩니다.
0
92
2
연관관계 매핑 질문드립니다.
0
85
2
h2데이터베이스 실행오류
0
107
2
persistence.xml
0
106
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
80
1
영속성 컨텍스트
0
64
1
JPA 프록시
0
94
1
Native Query와 MyBatis
0
67
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
85
1
임베디드 타입 예시 코드 관련 질문
0
114
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
94
3
인텔리제이 패키지 커서 단축키 질문
0
108
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
143
1





