Klausa VALUES boleh menjadi alat berguna untuk membina pertanyaan dalam pelbagai sistem pangkalan data. Walau bagaimanapun, dokumentasi SQLAlchemy terutamanya menyebut penggunaannya bersama-sama dengan pernyataan INSERT.
Untuk menangani had ini, SQLAlchemy kini menyediakan keupayaan untuk membina objek Pertanyaan yang menggabungkan klausa VALUES . Fungsi ini hampir sama dengan sintaks SQL klasik:
SELECT * FROM (VALUES (1, 2, 3)) AS sq;
Dalam SQLAlchemy, anda boleh mencapai hasil yang sama menggunakan kod berikut:
from sqlalchemy import select, column, Integer from sqlalchemy.sql import Values select(Values(column('Number', Integer), name='sq').data([(1,), (2,), (3,)]))
Kod ini menjana subquery yang memilih semua lajur daripada jadual maya (disediakan oleh ungkapan VALUES) bernama 'sq'.
Perlu diperhatikan bahawa ciri ini belum didokumenkan sepenuhnya. Walau bagaimanapun, untuk penerokaan lanjut, anda boleh merujuk kepada kes ujian yang tersedia di:
https://github.com/sqlalchemy/sqlalchemy/blob/master/test/sql/test_values.py
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan Klausa VALUES SQLAlchemy untuk Membina Pertanyaan Melebihi Pernyataan INSERT?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!