SQLAlchemy Core - Menggunakan Operasi Set

Di bab terakhir, kita telah belajar tentang berbagai fungsi seperti max (), min (), count (), dll., Di sini, kita akan belajar tentang operasi himpunan dan penggunaannya.

Operasi set seperti UNION dan INTERSECT didukung oleh SQL standar dan sebagian besar dialeknya. SQLAlchemy mengimplementasikannya dengan bantuan fungsi berikut -

Persatuan()

Saat menggabungkan hasil dari dua atau lebih pernyataan SELECT, UNION menghilangkan duplikat dari kumpulan hasil. Jumlah kolom dan tipe data harus sama di kedua tabel.

Fungsi union () mengembalikan objek CompoundSelect dari beberapa tabel. Contoh berikut menunjukkan penggunaannya -

from sqlalchemy import create_engine, MetaData, Table, Column, Integer, String, union
engine = create_engine('sqlite:///college.db', echo = True)

meta = MetaData()
conn = engine.connect()
addresses = Table(
   'addresses', meta, 
   Column('id', Integer, primary_key = True), 
   Column('st_id', Integer), 
   Column('postal_add', String), 
   Column('email_add', String)
)

u = union(addresses.select().where(addresses.c.email_add.like('%@gmail.com addresses.select().where(addresses.c.email_add.like('%@yahoo.com'))))

result = conn.execute(u)
result.fetchall()

Konstruksi gabungan diterjemahkan menjadi ekspresi SQL berikut -

SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ? UNION SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ?

Dari tabel alamat kami, baris berikut mewakili operasi serikat -

[
   (1, 1, 'Shivajinagar Pune', '[email protected]'),
   (2, 1, 'ChurchGate Mumbai', '[email protected]'),
   (3, 3, 'Jubilee Hills Hyderabad', '[email protected]'),
   (4, 5, 'MG Road Bangaluru', '[email protected]')
]

union_all ()

Operasi UNION ALL tidak dapat menghapus duplikat dan tidak dapat mengurutkan data dalam kumpulan hasil. Misalnya, dalam query di atas, UNION diganti dengan UNION ALL untuk melihat efeknya.

u = union_all(addresses.select().where(addresses.c.email_add.like('%@gmail.com')), addresses.select().where(addresses.c.email_add.like('%@yahoo.com')))

Ekspresi SQL yang sesuai adalah sebagai berikut -

SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ? UNION ALL SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ?

kecuali_()

SQL EXCEPTklausa / operator digunakan untuk menggabungkan dua pernyataan SELECT dan mengembalikan baris dari pernyataan SELECT pertama yang tidak dikembalikan oleh pernyataan SELECT kedua. Fungsi exception_ () menghasilkan ekspresi SELECT dengan klausa EXCEPT.

Dalam contoh berikut, fungsi kecuali_ () mengembalikan hanya catatan dari tabel alamat yang memiliki 'gmail.com' di bidang email_add tetapi mengecualikan yang memiliki 'Pune' sebagai bagian dari bidang postal_add.

u = except_(addresses.select().where(addresses.c.email_add.like('%@gmail.com')), addresses.select().where(addresses.c.postal_add.like('%Pune')))

Hasil dari kode di atas adalah ekspresi SQL berikut -

SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ? EXCEPT SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.postal_add LIKE ?

Dengan asumsi bahwa tabel alamat berisi data yang digunakan dalam contoh sebelumnya, itu akan menampilkan output berikut -

[(2, 1, 'ChurchGate Mumbai', '[email protected]'),
   (3, 3, 'Jubilee Hills Hyderabad', '[email protected]')]

memotong()

Menggunakan operator INTERSECT, SQL menampilkan baris umum dari kedua pernyataan SELECT. Fungsi intersect () mengimplementasikan perilaku ini.

Dalam contoh berikut, dua konstruksi SELECT adalah parameter ke fungsi intersect (). Satu baris kembali berisi 'gmail.com' sebagai bagian dari kolom email_add, dan baris hasil lainnya memiliki 'Pune' sebagai bagian dari kolom postal_add. Hasilnya adalah baris umum dari kedua kumpulan hasil.

u = intersect(addresses.select().where(addresses.c.email_add.like('%@gmail.com')), addresses.select().where(addresses.c.postal_add.like('%Pune')))

Akibatnya, ini sama dengan mengikuti pernyataan SQL -

SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.email_add LIKE ? INTERSECT SELECT addresses.id, 
   addresses.st_id, 
   addresses.postal_add, 
   addresses.email_add
FROM addresses
WHERE addresses.postal_add LIKE ?

Dua parameter terikat '% gmail.com' dan '% Pune' menghasilkan satu baris dari data asli di tabel alamat seperti yang ditunjukkan di bawah ini -

[(1, 1, 'Shivajinagar Pune', '[email protected]')]