SQLAlchemy ORM - Menerapkan Filter

Pada bab ini, kita akan membahas bagaimana menerapkan filter dan juga operasi filter tertentu beserta kodenya.

Resultset yang direpresentasikan oleh objek Query dapat dikenai kriteria tertentu dengan menggunakan metode filter (). Penggunaan umum metode filter adalah sebagai berikut -

session.query(class).filter(criteria)

Dalam contoh berikut, kumpulan hasil yang diperoleh dengan kueri SELECT pada tabel Pelanggan difilter oleh kondisi, (ID> 2) -

result = session.query(Customers).filter(Customers.id>2)

Pernyataan ini akan diterjemahkan ke dalam ekspresi SQL berikut -

SELECT customers.id 
AS customers_id, customers.name 
AS customers_name, customers.address 
AS customers_address, customers.email 
AS customers_email
FROM customers
WHERE customers.id > ?

Karena parameter terikat (?) Diberikan sebagai 2, hanya baris dengan kolom ID> 2 yang akan ditampilkan. Kode lengkap diberikan di bawah ini -

from sqlalchemy import Column, Integer, String
from sqlalchemy import create_engine
engine = create_engine('sqlite:///sales.db', echo = True)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()

class Customers(Base):
   __tablename__ = 'customers'
   
   id = Column(Integer, primary_key = True)
   name = Column(String)

   address = Column(String)
   email = Column(String)

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()
result = session.query(Customers).filter(Customers.id>2)

for row in result:
   print ("ID:", row.id, "Name: ",row.name, "Address:",row.address, "Email:",row.email)

Output yang ditampilkan di konsol Python adalah sebagai berikut -

ID: 3 Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]
ID: 4 Name: S.M.Krishna Address: Budhwar Peth, Pune Email: [email protected]