inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

탄탄한 백엔드 NestJS, 기초부터 심화까지

AWS RDS MySQL 구축 및 NestJS + TypeORM 프로젝트 셋업 (old)

TypeORM 트랜잭션 관련

507

front

작성한 질문수 5

1

안녕하세요 선생님, 좋은 강의 항상 감사드립니다.

 

TypeORM 트랜잭션과 관련해 궁금한 것이 생겼습니다.

 

1. 스프링의 경우 데이터베이스 관련 로직이 있는 서비스 계층 메서드에는 @Transactional 어노테이션을 사용해 트랜잭션 처리를 해주는 것으로 알고 있습니다.

반면, NestJS 공식 문서를 살펴보니 @Transactional() 데코레이터를 이용한 트랜잭션 처리를 권장하지 않고 있습니다. 이에 대한 이유는 설명해주지 않는 것 같습니다. 혹시 권장되지 않는 이유에 대해 알 수 있을까요?

 

2. NestJS에서는 @Transactional() 데코레이터를 대신해 QueryRunner를 권장하고 있습니다. 사용하는 법을 살펴보니 일일이 수동으로 트랜잭션을 처리해주는 방식인데, Nest 서비스 계층에서 RDB에 접근하는 로직이 존재하면 모두 QueryRunner를 이용해야 하나요? (서비스 로직이든 디비 접근에서든 오류가 발생하면 롤백해주어야 하므로 저는 그래야 한다고 생각합니다)

nodejs mongodb express NestJS ssr

답변 1

2

윤상석

안녕하세요! mdiu2203님! 

1. TypeORM에서 트렌젝션 처리는 크게 3가지로 할 수 있습니다. QueryRunner 방식, getConnection, getManager 방식, @Transactional 방식입니다.

제 개인적으로도 QueryRunner를 사용한다면 커밋, 롤백 등의 상태를 수동으로 제어할 수 있기 때문에  QueryRunner 방식이 좋다고 생각합니다. 

@Transactional 방식은 유닛테스트에서 레포지토리 모킹에 대한 어려움이 있습니다.

2. "무조건"이라고 단정 짓는 것은 조심스러우나 대부분의 DB 접근은 트랜젝션 처리를 하는 것이 좋습니다.

프로젝트 환경 세팅할 때 최신 노드 버젼을 사용하시는 분들은 참고하셔도 좋을 것 같아요~

2

84

1

DTO에 대한 질문

1

88

2

백엔드 MVC에서 View의 역할은 무엇인가요?

1

95

2

추가 업데이트 관련 건

0

93

2

nest js 버전문제

0

81

2

mongdb 스키마 공식 문서와 형태가 다른 이유 궁금합니다.

0

103

1

라인 끝에 에러 표시(eslint) 때문에 구글 찾아 보니.

0

77

1

전체 고양이 조회 라우터 중 error.message 오류

0

70

1

캡슐화 추가 설명 중 단일책임원칙 관련 질문

0

106

0

42강 고양이끼리 소통 댓글 구현 중 Schema hasn't been registered for model 'comments' 에러 해결

0

82

1

채팅 이슈

0

134

1

모듈이 더 이상 지원하지 않는답니다

0

207

1

오류가 있습니다

0

107

1

import 에서 오류가 납니다

0

128

1

이런 오류가 나옵니다

0

101

1

에러가 발생합니다

0

111

1

프론트 에러 뜨는데 수정 안해주시나요

0

159

1

emit() broadcast.emit() 질문있습니다

0

103

1

서버연결이 안됩니다.

1

403

1

[PM2][ERROR] Command not found

0

521

1

S3에 업로드까지는 성공했는데 사진이 나오지 않습니다.

0

249

1

error_code : Property 'user' does not exist on type 'Request<ParamsDictionary, any, any, ParsedQs, Record<string, any>>'.ts(2339)

0

603

1

jwt를 따로 연습하고 있는데 env를 못읽는 것 같습니다.

0

324

2

Ec2로 안하시는 이유가 있을까요?

0

343

1