[SpringBoot] JPA와 메소드 사용, @Entity, @Lombok

임유빈·2022년 8월 28일
post-thumbnail

JPA 사용하기 :

실제적으로 구현된 것이 아닌 구현된 클래스와 매핑을 해주기 위해 사용되는 프레임워크이다.

@Entity :

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

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

  • 필드에 final, enum, interface, class를 사용할 수 없다.
  • 생성자중 기본 생성자가 반드시 필요하다.

@Entity의 속성 :
name > 엔티티 이름을 지정한다. 기본값으로 클래스 이름을 그대로 사용한다.

JPA :

Member Entity를 분석한다.
INSERT SQL을 생성한다.
JDBC API를 사용하여 SQL을 DB에 날린다.


@Column :

객체 필드와 DB 테이블 컬럼을 맵핑한다.

@Column의 속성 :

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

Lombok :

DB 테이블의 column 과 같은 이름의 private 변수를 가지고, getter setter 메소드를 정의 한 후 toString 메소드를 정의한다. 프로젝트가 커지면 커질수록 위에 말한 변수 , 메소드들이 기하급수적으로 늘어날 것이고, 늘어나면 늘어날 수록 추가도 관리도 힘들어져 결국에는 유지보수가 힘들어진다. 위의 문제를 해결한 것이 Lombok이다.

@ToString : toString() 메소드 생성. @ToString(exclude={“제외값”})으로 제외 할 값을 설정할 수 있다.
@Getter , @Setter : getter() setter() 메소드를 생성한다.
@EqualsAndHashCode : equals(), hashCode() 메소드를 생성한다.
@RequiredArgsConstructor : 모든 멤버 변수를 초기화시키는 생성자를 생성한다.
@Data : 위에 언급한 5가지 어노테이션 설정을 모두 포함한다.

생성자를 자동 생성해주는 Lombok 어노테이션 :

@NorgsConstructor : 파라미터가 없는 기본 생성자 생성

@AllArgsConstructor : 모든 필드 값을 파라미터로 받는 생성자를 만들어 준다.

@RequiredArgsConstructor : final이나 @NonNull 인 필드 값만 파라미터로 받는 생성자를 만들어 준다.

@EqualsAndHashCode : equals, hashCode 자동 생성

  • equals : 두 객체의 내용이 같은지, 동등성(equality) 를 비교하는 연산자.

  • hashCode : 두 객체가 같은 객체인지, 동일성(identity) 를 비교하는 연산자


@Table : 맵핑할 테이블을 지정한다.
@Table의 속성 :

  • name : 매핑할 테이블의 이름을 지정
  • catalog : DB의 catalog를 맵핑
  • schema : DB 스키마와 맵핑
  • uniqueConstraint : DDL 쿼리를 작성할 때 제약 조건을 생성

객체 - 테이블 맵핑 : @Entity, @Table
필드 - 컬럼의 팹핑 : @Column
기본키의 맵핑 : @Id
조인 맵핑 : @ManyToOne, @JoinColumn


0개의 댓글