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

Mary-Kate Olsen
Lepaskan: 2024-11-09 20:00:03
asal
959 orang telah melayarinya

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()
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan