SQLAlchemy ORM - SQL Tekstual
Sebelumnya, teks SQL menggunakan fungsi text () telah dijelaskan dari perspektif bahasa ekspresi inti SQLAlchemy. Sekarang kita akan membahasnya dari sudut pandang ORM.
String literal dapat digunakan secara fleksibel dengan objek Query dengan menentukan penggunaannya dengan konstruksi text (). Sebagian besar metode yang dapat diterapkan menerimanya. Misalnya, filter () dan order_by ().
Dalam contoh yang diberikan di bawah ini, metode filter () menerjemahkan string "id <3" ke WHERE id <3
from sqlalchemy import text
for cust in session.query(Customers).filter(text("id<3")):
print(cust.name)
Ekspresi SQL mentah yang dihasilkan menunjukkan konversi filter ke klausa WHERE dengan kode yang diilustrasikan di bawah ini -
SELECT customers.id
AS customers_id, customers.name
AS customers_name, customers.address
AS customers_address, customers.email
AS customers_email
FROM customers
WHERE id<3
Dari data sampel kami di tabel Pelanggan, dua baris akan dipilih dan kolom nama akan dicetak sebagai berikut -
Ravi Kumar
Komal Pande
Untuk menentukan parameter mengikat dengan SQL berbasis string, gunakan titik dua, dan untuk menentukan nilai, gunakan metode params ().
cust = session.query(Customers).filter(text("id = :value")).params(value = 1).one()
SQL efektif yang ditampilkan pada konsol Python akan seperti yang diberikan di bawah ini -
SELECT customers.id
AS customers_id, customers.name
AS customers_name, customers.address
AS customers_address, customers.email
AS customers_email
FROM customers
WHERE id = ?
Untuk menggunakan pernyataan berbasis string sepenuhnya, konstruksi text () yang mewakili pernyataan lengkap dapat diteruskan ke from_statement ().
session.query(Customers).from_statement(text("SELECT * FROM customers")).all()
Hasil dari kode di atas akan menjadi pernyataan SELECT dasar seperti yang diberikan di bawah ini -
SELECT * FROM customers
Jelas, semua catatan di tabel pelanggan akan dipilih.
Konstruksi text () memungkinkan kita untuk menautkan SQL tekstualnya ke ekspresi kolom yang dipetakan oleh Core atau ORM secara posisional. Kita bisa mencapai ini dengan meneruskan ekspresi kolom sebagai argumen posisi ke metode TextClause.columns ().
stmt = text("SELECT name, id, name, address, email FROM customers")
stmt = stmt.columns(Customers.id, Customers.name)
session.query(Customers.id, Customers.name).from_statement(stmt).all()
Kolom id dan nama dari semua baris akan dipilih meskipun mesin SQLite mengeksekusi ekspresi berikut yang dihasilkan oleh kode di atas menunjukkan semua kolom dalam metode text () -
SELECT name, id, name, address, email FROM customers