일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- http
- gitrevert
- 김영한JPA
- 매핑정보가없는필드
- SpringBoot
- HTTPMESSAGE
- 자바ORM표준프로그래밍
- 멱등활용
- 캐쉬가능
- 데이터베이스 방언
- JPA
- 네이버로그인API
- Git
- DB방언
- initialDelay
- gitreset
- @Entity
- 무상태프로토콜
- anyMatch
- Transaction not successfully started
- @Table
- Invalid bound statement (not found)
- hibernate.dialect
- 네이버 연결된 서비스
- ERROR TYPE : org.apache.ibatis.binding.BindingException
- RFC723x
- org.apache.ibatis.binding.BindingException
- KAKAOLOGINAPI
- HTTP3
- fixedDelay
Archives
- Today
- Total
twocowsong
AUTO 전략 본문
깃허브 정리 URL : https://github.com/sWineTake/jpa.git
DB 종류도 많고 기본키를 만드는 방법도 다양합니다.
GenerationType.AUTO는 선택한 DB방언에 따라 IDENTITY, SEQUENCE, TABLE 전략 중 하나를 자동으로 선택합니다.
예를 들어 MySQL을 선택하면 IDENTITY를 사용합니다.
@Entity
public class BoardAuto {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
}
@GeneratedValue.strategy의 기본값은 AUTO 입니다.
따라서 아래와같이 사용해도 결과는 같습니다.
@Id
@GeneratedValue
private Long id;
AUTO 전략의 장점은 DB를 변경해도 코드를 수정할 필요가 없다는 장점이있습니다.
특히 키 생성 전략이 확정되지 않은 개발 초기 단계나 프로토타입 개발시 편리하게 사용할 수 있습니다.
AUTO사용 시 SEQUENCE나 TABLE 전략이 선택되면 시퀀스나 키 생성용 테이블을 미리 만들어 두어야 합니다.
(@TableGenerator 나 @SequenceGenerator 전략으로 생성시키지 않기때문입니다.)
만약 스키마 자동 생성 기능을 사용한다면 하이버 네이트가 기본값을 사용해서 적절한 시퀀스나 키 생성용 테이블을 만들어 줄 것입니다.
'IT > JPA' 카테고리의 다른 글
필드와 컬럼 매핑 : @Column (0) | 2022.05.18 |
---|---|
기본 키 매핑 정리 (0) | 2022.05.16 |
TABLE 전략 (0) | 2022.05.15 |
SEQUENCE 전략 (0) | 2022.05.14 |
IDENTITY 전략 (0) | 2022.05.13 |