Rumah  >  Artikel  >  pangkalan data  >  Bagaimanakah SQLAlchemy boleh mencapai sisipan pukal yang dioptimumkan seperti satu pernyataan SQL dan bukannya sisipan individu?

Bagaimanakah SQLAlchemy boleh mencapai sisipan pukal yang dioptimumkan seperti satu pernyataan SQL dan bukannya sisipan individu?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-09 20:00:03960semak imbas

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

Sisipan Pukal Dioptimumkan dalam SQLAlchemy ORM

Soalan:

Bolehkah SQLAlchemy melakukan sisipan pukal, serupa dengan pernyataan SQL tunggal (MASUKKAN KE DALAM foo (bar) NILAI (1), (2), (3)), bukannya melaksanakan sisipan berasingan untuk setiap objek?

Jawapan:

SQLAlchemy versi 1.0.0 memperkenalkan operasi pukal, termasuk sisipan pukal dan kemas kini.

Sisipan Pukal:

Dalam versi 1.0.0 dan lebih baru, SQLAlchemy menyokong sisipan pukal menggunakan kaedah bulk_save_objects():

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

Kod ini akan melakukan operasi sisipan pukal tunggal untuk menambah ketiga-tiga objek Pengguna.

Peningkatan Kecekapan:

Menggunakan sisipan pukal meningkatkan prestasi dengan ketara berbanding untuk melaksanakan sisipan berasingan bagi setiap objek.

Data dan Transaksi Lapuk:

Untuk mengekalkan ketekalan data, gunakan sesi dengan autocommit=False. Apabila anda melakukan transaksi secara manual menggunakan session.commit(), SQLAlchemy membuang objek yang diubah suai dan mengambil rekod yang dikemas kini semasa pertanyaan berikutnya. Walau bagaimanapun, pengubahsuaian pangkalan data daripada sumber luaran masih boleh menyebabkan isu data basi. Untuk mengurangkan perkara ini, pertimbangkan untuk menggunakan kunci pangkalan data untuk menguatkuasakan konsistensi transaksi.

Atas ialah kandungan terperinci Bagaimanakah SQLAlchemy boleh mencapai sisipan pukal yang dioptimumkan seperti satu pernyataan SQL dan bukannya sisipan individu?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn