twocowsong

@Table 본문

IT/JPA

@Table

WsCode 2022. 5. 9. 22:00

깃허브 정리 URL : https://github.com/sWineTake/jpa.git

 

GitHub - sWineTake/jpa: 자바 ORM 표준 JPA 프로그래밍 - 김영한

자바 ORM 표준 JPA 프로그래밍 - 김영한. Contribute to sWineTake/jpa development by creating an account on GitHub.

github.com

@Table은 엔티티와 매핑할 테이블을 지정합니다.

생략하면 엔티티 이름을 테이블 이름으로 사용합니다.

 

@Table 속성을 정리하였습니다.

- name : 매핑할 테이블 이름

- catalog : catalog 기능이 있는 DB에서 catalog를 매핑

- schema : schema 기능이 있는 DB에서 schema를 매핑

- uniqueConstraints : DDL 생성 시에 유니크 제약조건을 만듭니다. 2개 이상에 복합 유니크 제약조건도 만들 수 있습니다. 참고로 이 기능은 스키마 자동 생성 기능을 사용해서 DDL을 만들때만 사용됩니다.


- 시나리오 -

개발하던 회원 관리 프로그램에서 다음 요구사항이 추가되었습니다.

1. 회원은 일반 회원과 관리자로 구분해야합니다.

2. 회원 가입일과 수정일이 있어야 합니다.

3. 회원을 설명 할 수 있는 필드가 있어야 합니다. 이 필드는 길이 제한이 없습니다.

 

요구사항을 만족하도록 회원 엔티티에 기능을 추가해봅시다.

 

@Getter
@Setter
@NoArgsConstructor
@Entity
@Table(name = "MEMBER")
public class Member {

   @Id
   @Column(name = "ID")
   private String id;

   @Column(name = "NAME")
   private String username;

   private Integer age;

   // 추가
   @Enumerated(EnumType.STRING)
   private RoleType roleType;

   @Temporal(TemporalType.TIMESTAMP)
   private Date createDate;

   @Temporal(TemporalType.TIMESTAMP)
   private Date lastModifiedDate;

   @Lob
   private String description;

   // ========= 이전 생성자들 =========
   public Member(String id, String username) {
      this.id = id;
      this.username = username;
   }

   public Member(String id, String username, Integer age) {
      this.id = id;
      this.username = username;
      this.age = age;
   }
}

갑자기 처음보는 어노테이션들이 많아졌습니다. 자세하게 내용을 살펴봅시다.

 

roleType

- 자바의 enum을 사용해서 회원 타입을 구분하였습니다. 일반 회원은 USER, 관리자는 ADMIN입니다.

이처럼 자바의 enum을 사용하려면 @Enumerated 어노테이션이로 매핑해야 합니다.

 

createDate, lastModifiedDate

- 자바의 날짜 타입은 @Temporal을 사용해서 매핑해야합니다.

 

description

- 회원을 설명하는 필드는 길이 제한이 없습니다. 따라서 DB의 VARCHAR 타입대신 CLOB타입으로 저장해야 합니다.

@Lob을 사용하면 CLOB, BLOB타입을 매핑할 수 있습니다.

 

지금까지는 테이블을 먼저 생성하고 그다음에 엔티티를 만들었는데 이번에는 DB스키마 자동 생성을 사용해서 엔티티만 만들고 테이블은 자동 생성도되도록 해보겠습니다.

'IT > JPA' 카테고리의 다른 글

DDL생성 기능 - 제약 조건, 유니크 제약 조건  (0) 2022.05.10
DB스키마 자동 생성  (0) 2022.05.10
@Entity  (0) 2022.05.09
엔티티 매핑 시작  (0) 2022.05.09
영속성 관리 정리  (0) 2022.05.08