SQLAlchemy Core - Takma Adları Kullanma

SQL'deki diğer ad, "SELECT * FROM table1 AS a" dediğinizde ortaya çıkan bir tablonun veya SELECT deyiminin "yeniden adlandırılmış" bir sürümüne karşılık gelir. AS, tablo için yeni bir ad oluşturur. Takma adlar, herhangi bir tablo veya alt sorguya benzersiz bir adla başvurulmasına izin verir.

Tablo olması durumunda, bu aynı tablonun FROM yan tümcesinde birden çok kez adlandırılmasına izin verir. İfadeyle temsil edilen sütunlar için bir ana ad sağlar ve bu ada göre bunlara başvurulmasına izin verir.

SQLAlchemy'de, herhangi bir Tablo, select () yapısı veya diğer seçilebilir nesneler, From Clause.alias()Takma ad yapısı üreten yöntem. Sqlalchemy.sql modülündeki alias () işlevi, genellikle AS anahtar sözcüğünü kullanan bir SQL deyimi içindeki herhangi bir tabloya veya alt seçime uygulandığı gibi bir takma adı temsil eder.

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

Bu takma ad artık öğrenciler tablosuna başvurmak için select () yapısında kullanılabilir -

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

Bu, aşağıdaki gibi SQL ifadesine çevrilir -

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

Artık bu SQL sorgusunu bağlantı nesnesinin execute () yöntemi ile çalıştırabiliriz. Kodun tamamı aşağıdaki gibidir -

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

Yukarıdaki kod satırı çalıştırıldığında, aşağıdaki çıktıyı üretir -

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