[SPRING] 어노테이션 정리-3

CHOI IN HO·2023년 12월 29일
0

코딩테스트

목록 보기
29/74

@Entity

어노테이션을 클래스에 선언하면 그 클래스는 JPA가 관리한다. 그러므로 DB의 테이블과 Class(VO, DTO)와 맵핑한다면 반드시 @Entity를 붙여주어야 한다.

@Entity가 붙은 클래스에는 다음 제약사항이 필요하다.

필드에 final, enum, interface, class를 사용할 수 없다.
생성자중 기본 생성자가 반드시 필요하다.
@Entity의 속성
1. name : 엔티티 이름을 지정합니다. 기본값으로 클래스 이름을 그대로 사용한다.

@Table

@Table 어노테이션은 맵핑할 테이블을 지정한다.

@Table의 속성
1. name : 매핑할 테이블의 이름을 지정
2. catalog : DB의 catalog를 맵핑
3. schema : DB 스키마와 맵핑
4. uniqueConstraint : DDL 쿼리를 작성할 때 제약 조건을 생성

@Column

@Column 어노테이션은 객체 필드와 DB 테이블 컬럼을 맵핑한다.

@Column의 속성
1. name : 맵핑할 테이블의 컬럼 이름을 지정
2. insertable : 엔티티 저장시 선언된 필드도 같이 저장
3. updateable : 엔티티 수정시 이 필드를 함께 수정
4. table : 지정한 필드를 다른 테이블에 맵핑
5. nullable : NULL을 허용할지, 허용하지 않을지 결정
6. unique : 제약조건을 걸 때 사용
7. columnDefinition : DB 컬럼 정보를 직접적으로 지정할 때 사용
8. length : varchar의 길이를 조정합니다. 기본값으로 255가 입력
9. precsion, scale : BigInteger, BigDecimal 타입에서 사용, 각각 소수점 포함 자리수, 소수의 자리수를 의미

Coulmn 주의사항

  • 속성을 넣어주지 않아도 되는 컬럼은 어노테이션이 생량 가능하다
profile
개발자기 되기 위해선 무엇이든!

0개의 댓글