>데이터 베이스 >MySQL 튜토리얼 >SQLAlchemy는 개별 삽입 대신 단일 SQL 문과 같은 최적화된 대량 삽입을 어떻게 달성할 수 있습니까?

SQLAlchemy는 개별 삽입 대신 단일 SQL 문과 같은 최적화된 대량 삽입을 어떻게 달성할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-09 20:00:031036검색

How can SQLAlchemy achieve optimized bulk insertions like a single SQL statement instead of individual insertions?

SQLAlchemy ORM의 최적화된 대량 삽입

질문:

SQLAlchemy가 단일 SQL 문과 유사한 대량 삽입을 수행할 수 있습니까? (INSERT INTO foo (bar) VALUES (1), (2), (3)), 각 객체에 대해 별도의 삽입을 실행하는 대신?

답변:

SQLAlchemy 버전 1.0.0에는 대량 삽입 및 업데이트를 포함한 대량 작업이 도입되었습니다.

대량 삽입:

버전 1.0.0 이상에서 SQLAlchemy는 다음을 사용하여 대량 삽입을 지원합니다. Bulk_save_objects() 메서드:

s = Session()
objects = [
    User(name="u1"),
    User(name="u2"),
    User(name="u3")
]
s.bulk_save_objects(objects)
s.commit()

이 코드는 단일 대량 삽입 작업을 수행하여 세 개의 User 객체를 모두 추가합니다.

향상된 효율성:

대량 삽입을 활용하면 각 개체에 대해 별도의 삽입을 실행하는 것에 비해 성능이 크게 향상됩니다.

부실 데이터 및 트랜잭션:

데이터 일관성을 유지하려면 autocommit=False인 세션을 사용하세요. . session.commit()을 사용하여 트랜잭션을 수동으로 커밋하면 SQLAlchemy는 수정된 개체를 플러시하고 후속 쿼리 중에 업데이트된 레코드를 가져옵니다. 그러나 외부 소스에서 데이터베이스를 수정하면 여전히 오래된 데이터 문제가 발생할 수 있습니다. 이를 완화하려면 데이터베이스 잠금을 사용하여 트랜잭션 일관성을 강화하는 것이 좋습니다.

위 내용은 SQLAlchemy는 개별 삽입 대신 단일 SQL 문과 같은 최적화된 대량 삽입을 어떻게 달성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.