250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- execute
- 스토어드 프로시저
- dfs
- 일대다
- 지연로딩
- 낙관적락
- 연관관계
- eager
- PS
- 백트래킹
- exclusive lock
- 데코레이터
- 연결리스트
- querydsl
- 다대다
- 스프링 폼
- 유니크제약조건
- CHECK OPTION
- SQL프로그래밍
- 즉시로딩
- BOJ
- 동적sql
- 다대일
- FetchType
- 힙
- shared lock
- 비관적락
- fetch
- 이진탐색
- JPQL
Archives
- Today
- Total
흰 스타렉스에서 내가 내리지
@Transactional(readOnly = true) 본문
728x90
public PostsResponseDto findById(Long id){
Posts entity = postsRepository.findById(id)
.orElseThrow(() -> new IllegalArgumentException("해당 게시글이 없습니다. id=" + id));
return new PostsResponseDto(entity);
}
/**
* readOnly = true 옵션을 주면,
* 트랜잭션 범위는 유지하되, 조회 기능만 남겨두어 조회 속도가 개선되기 때문에,
* 등록, 수정, 삭제 기능이 전혀 없는 서비스 메서드에서 사용하는 것을 추천한다.
*/
@Transactional(readOnly = true)
public List<PostsListResponseDto> findAllDesc(){
return postsRepository.findAllDesc().stream()
.map(PostsListResponseDto::new)
.collect(Collectors.toList());
}
readOnly = true 옵션을 주면,
트랜잭션 범위는 유지하되, 조회 기능만 남겨두어 조회 속도가 개선되기 때문에,
등록, 수정, 삭제 기능이 전혀 없는 서비스 메서드에서 사용하는 것을 추천한다.
'Spring' 카테고리의 다른 글
로그 남기기 1 (0) | 2023.01.22 |
---|---|
Custom Annotation 어노테이션 만들기 (@LoginUser) (0) | 2023.01.18 |
스프링에서 Bean을 주입받는 방식 (0) | 2023.01.17 |
Filter, Interceptor, AOP의 차이 (0) | 2023.01.16 |
Spring Interceptor , 스프링 인터셉터 (0) | 2023.01.16 |