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!