inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 데이터 JPA

createUserId, updateUserId 와 같은 로그성 컬럼에 대한 문의를 드립니다

153

캬하하

작성한 질문수 1

0

현재 JPA 도입을 검토중에 있고, 팀원들이 스터디로 JPA를 학습하고 있습니다.

지금 고민 중인 것이 있어 강사님께 질문을 드립니다.

보통 아래의 로그성 컬럼을 추가하여 해당 엔터티를 누가 생성/수정했는지 기록하고 있습니다.

엔터티 조회 (목록 조회) 시에도 최종 수정자 정보를 join을 해서 보여줘야 되고요.

예: Post table (PostEntity)

예: created_at, create_user_id, updated_at, update_user_id

질문)

이 경우, PostEntity의 create_user_id, update_user_id 컬럼에도 relation을 추가하는 것이 일반적인 관례인가요?

@ManyToOne(... 생략)

UserEntity createUser;

@ManyToOne(...생략)

UserEntity updateUser;

Relation을 추가하자니, 거의 대부분의 Entity에 FK 가 생겨 뭔가 낭비같은 느낌이 들고...

Relation을 추가 안하자니, 등록자, 최종사용자 정보를 Join을 할수 가 없네요. (RawQuery로 받아내야 하는..)

실무에서는 위 같은 경우 어떻게 해결하는지 문의를 드립니다.

미리 답변에 감사드립니다.

JPA spring java

답변 1

0

백기선

추가해야죠. 말씀하신대로 FK 없이는 조회할 수 있는 방법이 없는데 당연히 추가해야죠. Spring Data JPA에서 제공하는 auditing 기능을 사용하시면 엔티티가 생기거나 수정될 때 자동으로 누가 언제 수정했는지 기록할 수 있습니다.

spring boot 2.7.13-SNAPSHOT trace 소문자 로그 안나옴

0

533

1

<스프링 데이터 Common: 기본 리포지토리 커스터마이징> 에 대한 질문

0

392

1

comment table에서 저장될떄 왜 id값이 2부터저장이되는건가요?

0

407

1

@EnableJpaRepositories 설정을 스프링부트가 어디에서 자동설정하나요?

0

450

0

PersistenceContext 관련 질문드립니다.

0

335

1

지금(Eager), 나중에(Lazy)의 의미를 모르겠습니다

0

338

1

transaction 구간이 길어질 경우의 처리방법 문의드립니다.

0

905

1

docker postgres

0

292

1

Multiple DataSource 사용 시 transaction 관련 질문 드립니다.

0

2908

1

entity 중 null이 아닌 필드만 update 할 방법이 있을까요?

0

1190

1

Eager 모드일 경우, join을 inner join으로 바꾸는 법이 있을까요?

0

385

1

엔티티를 상속받는 DTO가 일반적인가요?

1

1847

1

커스텀 타입 클래스를 String 타입 처럼 이용해 쿼리하는 방법에 대해 질문하고 싶습니다.

0

339

1

연관관계 매핑 어떤식으로 해야될지 감이 안잡힙니다.

0

566

4

EntityManager 주입시 Annotation관련 질문드립니다.

0

565

1

클래스 기반 프로젝션 사용 관련 질문

0

560

1

save 메서드 질문드립니다.

0

258

1

복잡한 통계쿼리도 JPA로 가능한가요?

2

5592

1

find 와 get의 차이가 무엇인가요?

0

890

1

실무에서 JPA 할 때 FK로 개발할때 연관관계를 꼭 맺어주어야 하나요?

0

998

1

\dt Did not find any relations.

0

481

1

소스코드는 어디서 볼 수 있을까요?

1

287

1

table 생성과 select 문에 대한 질문

0

174

1

스프링 데이터 RepositoryTest 관련 질문

0

2173

2