inflearn logo
강의

Course

Instructor

FastAPI Complete Guide

Applying Bind Variables and Error Handling for 0 Query Results

81강 한 건도 못찾았을 경우 질문

77

choiym08046706

3 asked

0

강의 잘 듣고 있습니다. 한 가지 의문이 생겨서 질문을 남깁니다.

한 건도 못찾은 겅우 HTTPException으로 try문을 벗어나게 되는데 이미 생성된 result(커서?)가 닫히는 부분은 없는 것 같아서요. conn.execute를 해서 커서를 열었으면 닫아줘야 하는 것 아닌가요?

python sql sqlalchemy FastAPI

Answer 2

1

dooleyz3525

안녕하십니까,

날카로운 지적이십니다 ^^

SQLAlchemy 버전에 따라 차이가 있을 수 있지만, 현 버전의 SQLAlchemy Connection Pool은 connection이 close()되어서 connection pool 로 돌아가면 자동으로 Cursor result를 닫아 줍니다.

따라서 오류가 발생해서 result의 close()를 수행할 수 없지만 connection close()가 finally에서 수행되므로 connection pool로 돌아가면서 자동으로 cursor result가 닫히게 됩니다.

그렇지만, 암묵적으로 connection close() 시에 이런 작업들이 수행되더라도, 명시적으로 cursor result를 닫아주는 것은 필수 입니다.

감사합니다.

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 열음님.

FastAPI 및 데이터베이스 연결과 관련된 질문을 주셨군요. 주로 데이터베이스에 쿼리를 실행하여 결과를 가져오는 과정에서 발생하는 상황에 대해 문의하셨습니다.

보통 데이터베이스 연결 및 커서는 사용 후 명시적으로 닫아주는 것이 중요합니다. 이는 리소스를 절약하고 메모리 누수를 방지하기 위해 필요합니다. Python에서는 with 구문을 통해 context manager를 활용하면 자동으로 연결을 닫을 수 있습니다. 예를 들어, 아래와 같은 방식을 사용할 수 있습니다:

async with engine.connect() as connection:
    result = await connection.execute(sa.select([table]))
    rows = result.fetchall()
    # 결과가 있으면 처리

이 경우 async with 구문을 통해 connection이 종료될 때 자동으로 닫히기 때문에 리소스를 안전하게 관리할 수 있습니다. result도 비슷한 방식으로 관리를 할 수 있는데, 이는 SQLAlchemy와 같은 ORM에서 적절한 종료를 통해 자동으로 관리되기도 합니다.

관련해서 유사한 질문과 답변이 있는지 찾아보시는 것도 추천드립니다:

위 내용을 참고하시어, 명시적인 리소스 관리를 통해 안정적인 애플리케이션 운용을 하시기 바랍니다. 추후 FastAPI의 lifecycle 이벤트도 살펴보시면 더욱 체계적인 리소스 관리를 할 수 있을 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

간단한 모델 서빙용으로 FastAPI를 공부하려고 합니다.

0

99

1

Update(수정)용 모델 질문 드립니다.

0

69

2

API 라우트 설계 시 중첩 구조 분리 기준 질문

0

84

2

signed cookie 와 jwt 토큰

0

107

2

비동기처리와 멀티스레드

0

118

2

fastapi의 가능성에 대해 궁금합니다.

0

123

1

어디가 필요없는 코드인지 알아내려면....

0

78

2

nginx를 사용하고 static 설정을 하는 경우도 app.mount 설정을 해야 하나요?

0

104

2

logout 태그 관련 질문

0

53

2

안녕하세요. 질문 하나 드려도 될까요?

0

94

1

64강: mysql-connector-python 버전 관련

0

94

2

152번 강의에서 질문이있습니다.

0

77

2

import 자동완성

0

57

1

FastAPI + Uvicorn 환경에서 메모리 누수 관련 문의드립니다.

0

334

2

EmailStr + max_length=40 같은 경우 질문

0

107

2

item_static.html 질문

0

112

2

uvicorn으로 로컬서버 올렸으나 사내 타 컴퓨터에서 접속이 안됨

0

269

2

머신러닝 백엔드 강좌 언제나오나요?

0

138

2

db connect

0

127

2

pydantic

0

120

2

url_for

0

94

2

react

0

113

2

autoflush=false에 대해 질문 드립니다.

0

134

2

docstring이 안 먹혀요

0

95

1