JPA hibernate.hbm2ddl.auto 매핑 어노테이션
@Column 컬럼 매핑
@Temporal 날짜 타입 매핑
@Enumerated enum타입 매핑
@Lob BLOB, CLOB 매핑
@Transient 특정 필드나 속성이 데이터베이스에 저장되지 않아야 함을 지정하는 데 사용
@Column
- name : 필드와 매핑할 테이블의 컬럼 이름
- insertable, updatable : 등록,변경 가능 여부
- nullable(DDL) : null값의 허용 여부를 설정, false로 설정하면 DDL 생성시에 not null 제약조건이 붙는다
- unique(DDL) : @Table의 uniqueConstraints와 같지만 한 털럼에 간단히 유니크 제약조건을 걸때 사용
- columnDefinition(DDL) : 데이터베이스 컬럼 정볼르 직접 줄수있다. ex)varchar(100) defalut 'EMPTY'
- length(DDL) : 문자 길이 제약조건, String 타입에만 사용한다
- precision, scale(DDL) : BigDecimal 타입에서 사용한다. precision은 소수점을 포함한 전체자리수, scale는 소수의 자리수
@Enumerated
value
EnumType.ORDINAL : enum 순서를 데이터베이스에 저장
EnumType.STRING : enum 이름을 데이터베이스에 저장
ORDINAL 사용 X
@Temporal
날짜 타입(java.util.Date, java.util.Calender)을 매핑할때 사용
참고 : LocalDate, LocalDateTime을 사용할때는 생략가능(최신 하이버네이트 지원)
value
TemporalType.DATE : 날짜, 데이터베이스 date 타입과 매핑(ex:2024-04-05)
TemporalType.TIME : 시간, 데이터베이스 time 타입과 매핑 (ex : 11:11:11)
TemporalType.TIMESTAMP : 날짜와 시간, 데이터베이스 timestamp타입과 매핑 (ex 2024-04-05 11:11:11)
@Lob
데이터베이스 BLOB,CLOB 타입과 매핑
- @Lob에는 지정할 수 있는 속성이 없다
- 매핑하는 필드 타입이 문자면 CLOB , 나머지는 BLOB
- CLOB : String, char[], java.sql.CLOB
- BLOG: byte[], java.sql.BLOB
'JPA' 카테고리의 다른 글
JPA 연관관계 매핑 (One to Many,Many to Many) (1) | 2024.02.23 |
---|---|
JPA 기본 키 매핑(Entity Mapping) GenerationType.IDENTITY, SEQUENCE, TABLE (0) | 2024.02.22 |
JPA hibernate.hbm2ddl.auto 데이터베이스 스키마 자동생성 (0) | 2024.02.21 |
JPA 플러시(flush) (1) | 2024.02.21 |
JPA PersistenceContext(영속성컨텍스트), 장점 (0) | 2024.02.21 |