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)