728x90
요구사항 추가
- 회원은 일반 회원과 관리자로 구분해야 한다.
- 회원 가입일과 수정일이 있어야 한다.
- 회원을 설명할 수 있는 필드가 있어야 한다. 이 필드는 길이 제 한이 없다.
Member Entity
@Entity
@Table(name = "Member")//테이블 명을 적어줄수 있다
public class Member {
@Id
private Long id;
@Column(name = "name",nullable = true,length = 10)
private String username;
private Integer age;
@Enumerated(EnumType.STRING) //DB에는 ENUM 타입이 없기 때문에 Enumerated 어노테이션을 사용한다.
private RoleType roleType;
@Temporal(TemporalType.TIMESTAMP) //날짜와 관련된 메핑
private Date createdDate;
@Temporal(TemporalType.TIMESTAMP)
private Date lastModifiedDate;
@Lob //varchar를 넘어서는 큰 컨텐츠를 넣을때 사용한다.
private String description;
//DB랑 신경쓰지 않고 싶은 데이터를 가지고 싶을때
@Transient
private int temp;
public Member(){
}
}
매핑 어노테이션
| 어노테이션 | 설명 |
| @Column | 컬럼 매핑 |
| @Temporal | 날짜 타입 매핑 |
| @Enumerated | enum 타입 매핑 |
| @Lob | BLOB, CLOB 매핑 |
| @Transient | 특정 필드를 컬럼에 매핑하지 않음(매핑 무시) |
@Column
| 속성 | 설명 | 기본값 |
| name | 필드와 매핑할 테이블의 컬럼 이름 | 객체의 필드 이름 |
| insertable, updatable | 등록, 변경 가능 여부 | TRUE |
| nullable(DDL) | null 값의 허용 여부를 설정한다. false로 설정하면 DDL 생성 시에 not null 제약조건이 붙는다 | |
| unique(DDL) | @Table의 uniqueConstraints와 같지만 한 컬럼에 간단히 유니크 제 약조건을 걸 때 사용한다. | |
| columnDefinition | (DDL) 데이터베이스 컬럼 정보를 직접 줄 수 있다. ex) varchar(100) default ‘EMPTY' | 필드의 자바 타입과 방언 정보를 사용해서 적절한 컬럼 타입 |
| length(DDL) | 문자 길이 제약조건, String 타입에만 사용한다. | 255 |
| precision, scale(DDL) | BigDecimal 타입에서 사용한다(BigInteger도 사용할 수 있다). precision은 소수점을 포함한 전체 자 릿수를, scale은 소수의 자릿수 다. 참고로 double, float 타입에는 적용되지 않는다. 아주 큰 숫자나 정 밀한 소수를 다루어야 할 때만 사용한다. | precision=19, scale=2 |
- unique 제약조건 같은 경우 @Column에 주는 것보다 Table에서 주는 것을 실무에서 많이 사용
@Enumerated
| 속성 | 설명 | 기본값 |
| value | EnumType.ORDINAL: enum 순서를 데이터베이스에 저장 EnumType.STRING: enum 이름을 데이터베이스에 저장 |
EnumType.ORDINAL |
- ORDINAL 사용하면 안 된다
- 기본값이 ORDINAL이기 때문에 숫자 형식으로 저장이 되는데 만약 Enum타입에 상태가 추가되면 그전의 데이터가 모두 문제가 된다.
@Temporal
| 속성 | 설명 | 기본값 |
| value | TemporalType.DATE: 날짜, 데이터베이스 date 타입과 매핑 (예: 2013–10–11) TemporalType.TIME: 시간, 데이터베이스 time 타입과 매핑 (예: 11:11:11) TemporalType.TIMESTAMP: 날짜와 시간, 데이터베이 스 timestamp 타입과 매핑(예: 2013–10–11 11:11:11) |
- 날짜 타입(java.util.Date, java.util.Calendar)을 매핑할 때 사용
- 참고: LocalDate, LocalDateTime을 사용할 때는 생략 가능(최신 하이버네이트 지원).
@Lob
- 데이터베이스 BLOB, CLOB 타입과 매핑
- @Lob에는 지정할 수 있는 속성이 없다.
- 매핑하는 필드 타입이 문자면 CLOB 매핑, 나머지는 BLOB 매핑
- CLOB: String, char[], java.sql.CLOB
- BLOB: byte[], java.sql. BLOB
@Transient
- 필드 매핑 X
- 데이터베이스에 저장 X, 조회 X
- 주로 메모리상에서만 임시로 어떤 값을 보관하고 싶을 때 사용
@Transient
private Integer temp;728x90
'자바 ORM 표준 JPA 프로그래밍(인프런)' 카테고리의 다른 글
| Ch04. 엔티티 매핑 - 실전 예제(요구사항 분석과 기본 매핑) (0) | 2021.12.10 |
|---|---|
| Ch04. 엔티티 매핑 - 기본 키 매핑 (0) | 2021.12.10 |
| Ch04. 엔티티 매핑 - 데이터베이스 스키마 자동 생성 (0) | 2021.12.10 |
| Ch04. 엔티티 매핑 - 객체와 테이블 매핑 (0) | 2021.12.10 |
| Ch03. 영속성 관리(내부 동작 방식) - 준영속 상태 (0) | 2021.12.09 |