
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