개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.03.30 11:50

TableSelect::lockShared에 대한 도움을 부탁드립니다.

목록
  • 해커랭크매니아 2일 전 2025.03.30 11:50
  • 1
    1
저는 TableSelect::lockShared에 관한 내용을 공부하고 있지만, 하나의 문제점이 있습니다.

TableSelect::lockShared을 사용하여 데이터베이스의 테이블을 잠금하는 방법에 대해 공부하고 있지만, lockShared와 lockExclusive의 차이점을 이해하지 못하고 있습니다.

lockShared와 lockExclusive의 차이점을 설명해주시거나, 어떠한 예제를 통해 이해할 수 있도록 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  2일 전



    TableSelect::lockShared과 lockExclusive의 차이점은 다음과 같습니다.

    - TableSelect::lockShared:
    - 다른 트랜잭션에서 읽기(Select)가 가능합니다.
    - 데이터베이스의 테이블을 잠금하지만, 다른 트랜잭션에서 읽기만 허용합니다.
    - 데이터베이스의 테이블을 잠금하지만, 다른 트랜잭션에서 읽기와 쓰기 모두 허용하지 않습니다.

    - TableSelect::lockExclusive:
    - 다른 트랜잭션에서 읽기(Select)와 쓰기(Insert, Update, Delete)가 모두 불가능합니다.
    - 데이터베이스의 테이블을 잠금하고, 다른 트랜잭션에서 읽기와 쓰기 모두 불허합니다.

    예를 들어, 다음과 같은 상황을 가정해 보겠습니다.

    - 사용자가 데이터베이스의 테이블을 읽기(Select)만 하려면 TableSelect::lockShared을 사용하면 됩니다.
    - 사용자가 데이터베이스의 테이블을 쓰기(Insert, Update, Delete)하거나, 다른 트랜잭션에서 읽기(Select)와 쓰기(Insert, Update, Delete)를 모두 방지하고 싶다면 TableSelect::lockExclusive을 사용하면 됩니다.

    2025-03-30 11:51

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 8,200건 / 10 페이지

검색

게시물 검색