HelloWorld

JPA 에서 자주 사용하는 어노테이션

웹(WEB)/spring-boot

@Entity

해당 클래스의 인스턴스들이 엔티티임을 명시한다.

 

@Table

클래스의 선언부에 작성하여 테이블명을 어떻게 정할지 결정한다. @Table 을 지정하지 않으면, 클래스명으로 테이블이 생성된다.

 

@Id

해당 컬럼이 Primary Key임을 명시한다. 모든 엔티티에는 반드시 @Id를 지정해 주어야한다.

주로, @GeneratedValue 와 함께 사용되어 식별키를 어떤방식으로 생성할지 명시해준다.

 

@Column

객체 필드를 테이블 컬럼과 매핑해주는 어노테이션이다. 다양한 속성이 존재하지만 name, nummable 이 가장 많이 사용된다.

  • name : 매핑할 table의 컬럼 이름, 기본은 객체의 필드 이름을 사용한다.
  • insertable : 거의 사용하지 않는다. 엔티티 저장시 이 필드도 저장하라는 의미로 기본은 true이다. 단, false로 하면 Readonly일 때 사용가능하다.
  • updatable : 거의 사용하지 않는다. 엔티티 수정시 이 필드도 수정하라는 의미로 기본은 true이다. 단, false로 하면 Readonly일 때 사용가능하다.
  • table : 거의 사용하지 않는다. 하나의 엔티티를 두 개 이상의 테이블에 매핑할 때 사용한다.
  • nullable : false로 설정하면 DDL생성시에 "NOT NULL" 제약조건을 추가해준다.
  • unique : @Table 의 uniqueConstraints와 같지만 한 컬럼에 대해서 적용할 때는 간단하게 이걸 이용할 수 있다. 단 여러 컬럼을 사용할때는 @Table 의 uniqueConstraints를 사용해야 한다.
  • columnDefinition : 사용자가 직접 컬럼의 정보를 입력할 수 있다.
  • length : 문자 길이에 대한 제약조건을 추가한다. String 타입에만 적용되며 기본값은 255이다.
  • precision, scale : BigDecimal 타입에서 사용된다. precision은 소수점을 포함한 전체 자릿수, scale은 소수 자릿수를 의미한다. float, double에는 해당되지 않는다.

 

@ManyToOne, @OneToOne, @OneToMany, @ManyToOne,  @ManyToMany, @JoinColumn

 

@GeneratedValue

기본키가 자동으로 할당되도록 설정한다. 기본키 할당전략을 선택할 수 있는데, AUTO, TABLE, SEQUENCE, IDENTITY 가 있다.

  • AUTO : 특정 데이터베이스에 맞게 자동으로 생성되는 방식이다. Oracle의 경우 SEQUENCE, MySQL의 경우 IDENTITY를 사용한다.
  • TABLE : 별도의 키를 생성해주는 테이블을 이용하는 방식이다. 키 생성 전용 Table을 만들어서 이를 SEQUENCE처럼 사용한다.
  • SEQUENCE : 데이터베이스의 시퀀스를 이용해서 식별키를 생성하는 방식이다.(Oracle에서 사용)
  • IDENTITY : 기본키 생성을 데이터베이스에 위임하는 방식이다. MySQL의 AUTO_INCREMENT와 같다. @GeneratedValue(strategy = GenerationType.IDENTITY) 로 설정가능하다.

 

@Enumerated

Enum 타입 매핑용 어노테이션이다. 자바 enum형과 데이터베이스 데이터 변환을 지원한다.

  • EnumType.ORDINAL : enum의 순서를 DB에 저장한다. 이 값이 Default 이다. 숫자로 저장되므로 데이터크기가 작아지고 빠르다. enum의 순서를 변경할 수 없는 단점이 있다.
  • EnumType.STRING : 실제로는 자바 enum형이지만 데이터베이스의 String형으로 변환하여 저장하겠다고 선언하는 것이다.

'웹(WEB) > spring-boot' 카테고리의 다른 글

[Template Engine] 타임리프(Thymeleaf)  (0) 2019.10.16
Lombok에서 자주 사용되는 어노테이션  (0) 2019.10.09