안녕하세요 이번 글에서는 Enttiy에서 사용하는 몇 가지 annotation을 정리해 보겠습니다.
[ 클래스에 선언 ]
@Entity
> JPA 가 관리하는 엔티티로 설정된다. JPA를 사용해서 테이블과 매핑할 클래스는 @Entitty를 필수로 선언하여야 한다.
> 기본 생성자 필수 , final 클래스, enum, interface, inner 클래스 사용 X
> 저장할 필드에 final 사용 X
@Table
> 엔티티와 매핑할 테이블을 지정
> 속성
name : 매핑할 테이블 이름
catalog : 데이터베이스 catalog 매핑
schema : 데이터베이스 schema 매핑
uniqueConstraints : DDL 생성 시에 유니크 제약 조건 생성
[ 필드에 선언 ]
@Id
> PK 칼럼으로 사용할 필드 값에 선언
@Column
> 컬럼 매핑
> 속성
name : 필드와 매핑할 테이블의 칼럼 이름
insertable / updattable : 등록 , 변경 가능 여부
nullable(DDL) : null 값의 허용 여부를 설정한다. false로 설정하면 DDL 생성 시에 not null 제약조건이 붙는다.
unique(DDL) : @Table의 uniqueConstraint와 같지만 한 칼럼에 간단히 유니크 제약조건을 걸 때 사용한다.
columnDefinition (DDL) : 데이터베이스 칼럼 정보를 직접 줄 수 있다.
length(DDL) : 문자 길이 제약조건, String 타입에만 사용한다.
precision, scale(DDL) : precision은 소수점을 포함한 전체 자릿수를, scale은 소수의 자릿수 다. 참고로 double, float 타입에는 적용되지 않는다. 아주 큰 숫자나 정 밀한 소수를 다루어야 할 때만 사용한다.
@Enumerated
> 자바 enum 타입을 매핑할 때 사용
> EnumType.ORDINAL = enum 순서를 데이터베이스에 저장
> EnumType.STRING = enum 이름을 데이터베이스에 저장
@Temporal
> 날짜 타입을 매핑할 때 사용
> LocalDate, LocalDateTime을 사용할 때는 생략 가능
@Lob
> DB의 BLOB, CLOB 타입과 매핑
> 메핑 하는 필드 타입의 문자면 CLOB, 나머지는 BLOB 매핑
@Transient
> 필드 매핑 X , 데이터베이스에 저장 X , 조회 X
> 주로 메모리상에서만 임시로 어떤 값을 보관하고 싶을 때 사용
감사합니다 ^^
'Spring & Spring Boot' 카테고리의 다른 글
[ Spring-Boot ] JPA QueryDsl 정렬 사용하기 (1) | 2021.05.23 |
---|---|
[ Spring-Boot ] JPA Embedded 타입 사용하기 (0) | 2021.05.23 |
[ Spring-Boot ] JPA @GeneratedValue 사용하기 (0) | 2021.05.22 |
[ Spring-Boot ] JPA 공통 Entity 만들기 (0) | 2021.05.22 |
[ Spring-Boot ] @Controller 에서 파라미터 받기 (0) | 2021.05.22 |