해결된 질문
작성
·
246
·
수정됨
0
학습 관련 질문을 최대한 상세히 남겨주세요!
고민 과정도 같이 나열해주셔도 좋습니다.
먼저 유사한 질문이 있었는지 검색해보세요.
인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
안녕하세요!
10:30초 쯤부터 설명해주시는 내용이 잘 이해가 안가서 질문드립니다.
article 테이블에
insert 문과 update 문을 동시에 실행한다고 하더라도 서로 다른 레코드에 대한 작업이어서 update문이 실행될 때 x-lock이 걸리는 레코드는 insert하는 레코드와 상관 없을 거라고 생각했는데
게시글 쓰기와 좋아요 수 쓰기 작업을 할 때 어떻게 동일한 레코드에 락이 걸릴 수 있는지 상황이 잘 안그려지네요..
게시글을 새로 작성하는 경우가 아니라 게시글 수정 - 좋아요 수 업데이트 간에 동일한 레코드에 대한 락이 잡힐 수 있는 상황을 말씀하신 건가요??
답변 2
2
eoyeong님, 안녕하세요!
설명이 일부 부족한 부분이 있었네요. 보충 설명 드립니다!
article insert 시점에는 어차피 좋아요 동작도 수행할 수 없으므로, 레코드 락이 충돌될 상황은 발생하지 않는게 맞습니다.
"쓰기 작업"이라는 용어 때문에 혼동이 있었을 것 같은데요,
"쓰기 작업"이라는 단어가 관점에 따라 생성/수정/삭제를 모두 포함하는 용어로 해석할 수 있기도 하지만, "게시글 수정 작업"이라는 용어로 표현하는게 더욱 명확했을 수도 있겠네요.
(DB 관점(?)에서는 읽기(READ), 쓰기(CREATE/UPDATE/DELETE)로 표현되기도 합니다!)
말씀하신대로 "게시글 수정 - 좋아요 수 업데이트"에 대한 상황이 맞습니다! (정확히는 삭제의 경우도 가능하겠네요)
혹시 더 궁금한 점 있으시면 편히 문의 주세요!
0
안녕하세요, 인프런 AI 인턴입니다. ga님.
질문해주신 내용은 데이터베이스의 락(lock) 메커니즘과 관련이 있습니다. 특히나 데이터베이스에서의 쓰기와 갱신 작업이 서로에게 어떤 영향을 줄 수 있는지에 대한 부분인데요, 몇 가지 개념을 이해하시면 도움이 되실 것 같습니다.
관련 유사한 설명이나 질문에 대한 자세한 예제가 아래 게시글에서 다루어질 수 있습니다:
- 데이터베이스 락과 동시성 문제 해결 방법
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
답변 감사합니다!!
주제가 게시글이라 말씀처럼 쓰기라는게 insert를 의미하는 걸로 혼동했네요 ㅎㅎ
강의 들으면서 많은 걸 배우고 있습니다 :)