작성
·
936
0
JPA 에서 unique한 칼럼에 같은 이름의 row가 존재 하지 않을 경우에만 insert를 하고 그렇지 않은 경운 업데이트 하는 로직을 작성하고 싶은데요.. 객체 입장에서는 단순히 find 후에 결과가 null이면 삽입 하고, 그렇지 않으면 set 하는 로직이 될 것 같은데.. 이게 쿼리 레벨로 변환 되면 멀티쓰레드 동작 시 문제가 될 것 같은데요...
구글링을 해보면 여러 솔루션들이 나오는데 뭔가 정답 같은 딱 떨어지는 건 없는 것 같네요.. JPA 단에서 원자적으로 처리하는 방법이 있는지 궁금합니다. 아니면 최대한 비지니스 로직이나 테이블 설계에서 이런 상황을 피하는 것이 최선일까요?
답변 1
0
안녕하세요. Woo-seok Choi님 좋은 질문입니다.
먼저 일반적인 경우에는 같은 이름의 row의 등록이 중복으로 요청되는 경우는 거의 없기 때문에 문제가 되지 않습니다. 문제가 된다고 해도 unique 제약조건으로 인해서 한쪽은 실패하게 되겠지만, 이후에 다시 시도하면 되겠지요? 이것을 사용자가 다시 시도해도 되고, 시스템이 다시 시도해도 됩니다.
그런데 정말 트래픽이 많고, 고성능으로 이 부분을 잘 처리해야 한다면, 각 데이터베이스가 제공하는 upsert 같은 네이티브 기능을 사용하는 것이 좋습니다.
감사합니다.