SQLAlchemy Core - Memilih Baris
Pada bab ini, kita akan membahas tentang konsep pemilihan baris pada objek tabel.
Metode select () dari objek tabel memungkinkan kita melakukannya construct SELECT expression.
s = students.select()
Objek yang dipilih diterjemahkan menjadi SELECT query by str(s) function seperti yang ditunjukkan di bawah ini -
'SELECT students.id, students.name, students.lastname FROM students'
Kita dapat menggunakan objek pilihan ini sebagai parameter untuk mengeksekusi () metode objek koneksi seperti yang ditunjukkan pada kode di bawah ini -
result = conn.execute(s)
Ketika pernyataan di atas dijalankan, shell Python menggema mengikuti ekspresi SQL yang setara -
SELECT students.id, students.name, students.lastname
FROM students
Variabel yang dihasilkan setara dengan kursor di DBAPI. Kami sekarang dapat mengambil catatan menggunakanfetchone() method.
row = result.fetchone()
Semua baris yang dipilih dalam tabel dapat dicetak dengan a for loop seperti yang diberikan di bawah ini -
for row in result:
print (row)
Kode lengkap untuk mencetak semua baris dari tabel siswa ditunjukkan di bawah ini -
from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String
engine = create_engine('sqlite:///college.db', echo = True)
meta = MetaData()
students = Table(
'students', meta,
Column('id', Integer, primary_key = True),
Column('name', String),
Column('lastname', String),
)
s = students.select()
conn = engine.connect()
result = conn.execute(s)
for row in result:
print (row)
Output yang ditampilkan dalam shell Python adalah sebagai berikut -
(1, 'Ravi', 'Kapoor')
(2, 'Rajiv', 'Khanna')
(3, 'Komal', 'Bhandari')
(4, 'Abdul', 'Sattar')
(5, 'Priya', 'Rajhans')
Klausa WHERE dari kueri SELECT dapat diterapkan dengan menggunakan Select.where(). Misalnya jika kita ingin menampilkan baris dengan id> 2
s = students.select().where(students.c.id>2)
result = conn.execute(s)
for row in result:
print (row)
Sini c attribute is an alias for column. Output berikut akan ditampilkan di shell -
(3, 'Komal', 'Bhandari')
(4, 'Abdul', 'Sattar')
(5, 'Priya', 'Rajhans')
Di sini, kita harus mencatat bahwa objek tertentu juga dapat diperoleh dengan fungsi select () dalam modul sqlalchemy.sql. Fungsi select () membutuhkan objek tabel sebagai argumen.
from sqlalchemy.sql import select
s = select([users])
result = conn.execute(s)