강의

멘토링

커뮤니티

Cộng đồng Hỏi & Đáp của Inflearn

Hình ảnh hồ sơ của choiym08046706
choiym08046706

câu hỏi đã được viết

Hướng dẫn đầy đủ về FastAPI

Áp dụng biến Bind và xử lý lỗi khi kết quả trả về 0 bản ghi

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

Viết

·

70

·

Đã chỉnh sửa

0

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

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

pythonsqlsqlalchemyFastAPI

Câu trả lời 2

1

dooleyz3525님의 프로필 이미지
dooleyz3525
Người chia sẻ kiến thức

안녕하십니까,

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

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

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

Hình ảnh hồ sơ của choiym08046706
choiym08046706

câu hỏi đã được viết

Đặt câu hỏi