SQLAlchemy ORM - Menggunakan Query
Semua pernyataan SELECT yang dibuat oleh SQLAlchemy ORM dibuat oleh objek Query. Ini menyediakan antarmuka generatif, oleh karena itu panggilan berturut-turut mengembalikan objek Query baru, salinan sebelumnya dengan kriteria dan opsi tambahan yang terkait dengannya.
Objek kueri awalnya dibuat menggunakan metode query () dari Sesi sebagai berikut -
q = session.query(mapped class)
Pernyataan berikut juga setara dengan pernyataan yang diberikan di atas -
q = Query(mappedClass, session)
Objek kueri memiliki metode all () yang mengembalikan kumpulan hasil dalam bentuk daftar objek. Jika kami menjalankannya di meja pelanggan kami -
result = session.query(Customers).all()
Pernyataan ini secara efektif setara dengan mengikuti ekspresi SQL -
SELECT customers.id
AS customers_id, customers.name
AS customers_name, customers.address
AS customers_address, customers.email
AS customers_email
FROM customers
Objek hasil dapat ditelusuri menggunakan perulangan For seperti di bawah ini untuk mendapatkan semua rekaman dalam tabel pelanggan yang mendasarinya. Berikut adalah kode lengkap untuk menampilkan semua catatan di tabel Pelanggan -
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).all()
for row in result:
print ("Name: ",row.name, "Address:",row.address, "Email:",row.email)
Konsol Python menampilkan daftar record seperti di bawah ini -
Name: Ravi Kumar Address: Station Road Nanded Email: [email protected]
Name: Komal Pande Address: Koti, Hyderabad Email: [email protected]
Name: Rajender Nath Address: Sector 40, Gurgaon Email: [email protected]
Name: S.M.Krishna Address: Budhwar Peth, Pune Email: [email protected]
Objek Query juga memiliki metode berguna berikut -
Sr.No. | Metode & Deskripsi |
---|---|
1 | add_columns() Ini menambahkan satu atau lebih ekspresi kolom ke daftar kolom hasil yang akan dikembalikan. |
2 | add_entity() Ini menambahkan entitas yang dipetakan ke daftar kolom hasil yang akan dikembalikan. |
3 | count() Ini mengembalikan hitungan baris yang akan dikembalikan Kueri ini. |
4 | delete() Itu melakukan kueri penghapusan massal. Menghapus baris yang cocok dengan kueri ini dari database. |
5 | distinct() Ini menerapkan klausa DISTINCT ke kueri dan mengembalikan Kueri yang baru dihasilkan. |
6 | filter() Ini menerapkan kriteria pemfilteran yang diberikan ke salinan Kueri ini, menggunakan ekspresi SQL. |
7 | first() Ini mengembalikan hasil pertama dari Query ini atau None jika hasilnya tidak berisi baris apa pun. |
8 | get() Ini mengembalikan sebuah instance berdasarkan pengenal kunci utama yang diberikan yang memberikan akses langsung ke peta identitas dari Sesi yang memiliki. |
9 | group_by() Ini menerapkan satu atau lebih kriteria GROUP BY ke kueri dan mengembalikan Kueri yang baru saja dihasilkan |
10 | join() Ini membuat SQL JOIN terhadap kriteria objek Query ini dan menerapkan secara umum, mengembalikan Query yang baru dihasilkan. |
11 | one() Ini mengembalikan tepat satu hasil atau memunculkan pengecualian. |
12 | order_by() Ini menerapkan satu atau beberapa kriteria ORDER BY ke kueri dan mengembalikan Kueri yang baru dihasilkan. |
13 | update() Itu melakukan kueri pembaruan massal dan memperbarui baris yang cocok dengan kueri ini di database. |