작성
·
125
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
여기에 질문 내용을 남겨주세요.
조회만을 위한 메서드를 작성할때 쿼리 힌트를 사용하는것보다 트랜잭셔널 메소드 레벨 어노테이션에 readOnly=true 속성을 넣어서 읽기 전용으로 사용하면 안되나요?
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
묵국님의 질문에 관련하여, 데이터 접근에서 읽기 전용 트랜잭션인 @Transactional(readOnly = true)
를 사용하는 것과 관련된 질문들 중 하나를 참고하실 수 있겠습니다. 해당 내용은 읽기 전용 트랜잭션을 어노테이션을 통해 어떻게 활용할 수 있는지, 그리고 이것이 성능상의 이점을 어떻게 가져올 수 있는지에 대한 설명을 포함하고 있습니다.
이 글에서는 서비스에서 Select문만을 호출하는 메서드에 @Transactional(readOnly = true)
를 적용하는 것과 트랜잭셔널 어노테이션을 적용하지 않는 것 중 어느 것이 성능상 이점이 있는지에 대한 논의가 있습니다. 답변에서는 DB마다 결과가 다를 수 있으며, 읽기 전용 트랜잭션을 적용해 DB에서 최적화를 할 수도 있지만, 경우에 따라 네트워크 통신이 한 번 더 일어나 성능에 불리할 수도 있다는 지식공유자의 설명이 있습니다. 그러므로 이 부분은 DB의 성능 특성을 고려하여 결정해야 함을 강조합니다.
결국, @Transactional(readOnly = true)
속성을 통해 읽기 전용으로 메서드를 사용하는 것은 데이터의 일관성을 유지하며 성능 최적화를 도모할 수 있는 방법 중 하나입니다. 하지만, 데이터베이스와 애플리케이션의 특성을 고려해서 적용해야 하며, 모든 상황에서 일률적인 성능 향상을 기대하기는 어렵습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.