작성
·
1.6K
0
안녕하세요
JPA 강의 잘 듣고 있습니다.
. 문의 내용
Users 모델의 Repository 에서 @Id 가 사용자 ID (String)인 경우 save 할때 알아서 insert / update 목적
. 코드
@Entity
@SuperBuilder
@Getter @Setter
@NoArgsConstructor
public class Users extends JpaBaseEntity{
@Id
@Column(name = "userid", unique = true)
private String id;
private String name;
private String departmentName;
@JsonIgnore
private LocalDateTime lastLogin;
@JsonIgnore
private String ip;
@JsonIgnore
@Enumerated(EnumType.STRING)
private Authority authority;
@Override
public String getId(){
return id;
}
}
@Getter
@MappedSuperclass @SuperBuilder
@NoArgsConstructor @AllArgsConstructor
public abstract class JpaBaseEntity implements Persistable<String> {
@Column(updatable = false)
protected LocalDateTime createdDateTime;
protected LocalDateTime updatedDateTime;
@Transient
protected boolean isCreatedMode;
@Override
public boolean isNew() {
return isCreatedMode;
}
@PrePersist
private void prePersist() {
createdDateTime = LocalDateTime.now();
}
@PreUpdate
private void preUpdate() {
updatedDateTime = LocalDateTime.now();
}
}
String 형태의 Id 를 사용할 경우 JPA 내부에서 알아서 신규건(insert)인지 기존건(update)인지 확인하기 위해서 extends 를 위한 객체만들었습니다.
위와 같이 한 후 save 하는데, 원하는 결과가 아니고 동일 값을 insert 시도를 해서 에러가 발생하네요 ㅠ
. 콘솔 에러
ERROR 42980 --- [nio-9999-exec-1] o.h.engine.jdbc.spi.SqlExceptionHelper : Unique index or primary key violation: "PUBLIC.PRIMARY_KEY_4 ON PUBLIC.USERS(USERID) VALUES ( /* 1 */ '아이디' )"; SQL statement:
급한 마음에 '스프링 데이터 JPA' 까지 수강 이전 순수 JPA 로만 구현하고 있어 모르는 부분이 많습니다.
답변 부탁드리겠습니다 (문의 전 관련 키워드 검색해봐도 없어서 문의 남깁니다)
답변 1
1
답변 감사합니다.
isNew 함수 내에서 String id 의 검색여부가 반환하기 위한 방법은 어떻게 수정하면 될까요?
isCreatedMode 값이 아닌 함수 내에서 ID 값을 리턴하면 될까요?