SQLAlchemy Core - Menggunakan Alias

Alias ​​dalam SQL sesuai dengan versi "berganti nama" dari tabel atau pernyataan SELECT, yang terjadi setiap kali Anda mengatakan "SELECT * FROM table1 AS a". AS membuat nama baru untuk tabel tersebut. Alias ​​memungkinkan tabel atau subkueri apa pun untuk direferensikan dengan nama unik.

Dalam kasus tabel, ini memungkinkan tabel yang sama diberi nama dalam klausa FROM beberapa kali. Ini memberikan nama induk untuk kolom yang diwakili oleh pernyataan, memungkinkan mereka untuk direferensikan relatif terhadap nama ini.

Di SQLAlchemy, tabel apa pun, konstruksi select (), atau objek lain yang dapat dipilih dapat diubah menjadi alias menggunakan From Clause.alias()metode, yang menghasilkan konstruksi Alias. Fungsi alias () dalam modul sqlalchemy.sql mewakili alias, seperti yang biasanya diterapkan ke tabel atau sub-pilih apa pun dalam pernyataan SQL menggunakan kata kunci AS.

from sqlalchemy.sql import alias
st = students.alias("a")

Alias ​​ini sekarang dapat digunakan dalam konstruksi select () untuk merujuk ke tabel siswa -

s = select([st]).where(st.c.id>2)

Ini diterjemahkan menjadi ekspresi SQL sebagai berikut -

SELECT a.id, a.name, a.lastname FROM students AS a WHERE a.id > 2

Sekarang kita bisa mengeksekusi query SQL ini dengan metode execute () dari objek koneksi. Kode lengkapnya adalah sebagai berikut -

from sqlalchemy.sql import alias, select
st = students.alias("a")
s = select([st]).where(st.c.id > 2)
conn.execute(s).fetchall()

Ketika baris kode di atas dijalankan, itu menghasilkan output berikut -

[(3, 'Komal', 'Bhandari'), (4, 'Abdul', 'Sattar'), (5, 'Priya', 'Rajhans')]