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]