Inflearn brand logo image

인프런 커뮤니티 질문&답변

열음님의 프로필 이미지
열음

작성한 질문수

FastAPI 완벽 가이드

Bind 변수 적용 및 조회 결과 0건 시 오류 처리

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

작성

·

19

·

수정됨

0

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

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

답변 2

0

권 철민님의 프로필 이미지
권 철민
지식공유자

안녕하십니까,

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

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

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

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

감사합니다.

0

안녕하세요, 인프런 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 이벤트도 살펴보시면 더욱 체계적인 리소스 관리를 할 수 있을 것입니다.

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

열음님의 프로필 이미지
열음

작성한 질문수

질문하기