SQLAlchemy ORM - İlişki Kurmak

Bu oturum, veritabanımızda zaten var olan bir tabloyla ilgili başka bir tablonun oluşturulmasını açıklar. Müşteriler tablosu müşterilerin ana verilerini içerir. Şimdi, bir müşteriye ait herhangi bir sayıda faturayı içerebilecek faturalar tablosu oluşturmamız gerekiyor. Bu, birden çok ilişkiye dair bir durumdur.

Bildirime dayalı kullanarak, bu tabloyu eşlenmiş sınıfı olan Faturalar ile birlikte aşağıda verildiği gibi tanımlarız -

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

class Customer(Base):
   __tablename__ = 'customers'

   id = Column(Integer, primary_key = True)
   name = Column(String)
   address = Column(String)
   email = Column(String)

class Invoice(Base):
   __tablename__ = 'invoices'
   
   id = Column(Integer, primary_key = True)
   custid = Column(Integer, ForeignKey('customers.id'))
   invno = Column(Integer)
   amount = Column(Integer)
   customer = relationship("Customer", back_populates = "invoices")

Customer.invoices = relationship("Invoice", order_by = Invoice.id, back_populates = "customer")
Base.metadata.create_all(engine)

Bu, aşağıdaki gibi SQLite motoruna CREATE TABLE sorgusu gönderecektir -

CREATE TABLE invoices (
   id INTEGER NOT NULL,
   custid INTEGER,
   invno INTEGER,
   amount INTEGER,
   PRIMARY KEY (id),
   FOREIGN KEY(custid) REFERENCES customers (id)
)

Sales.db'de yeni tablonun oluşturulup oluşturulmadığını SQLiteStudio aracı yardımıyla kontrol edebiliriz.

Faturalar sınıfı, custid özelliğine ForeignKey yapısını uygular. Bu yönerge, bu sütundaki değerlerin müşteri tablosundaki id sütununda bulunan değerler olarak sınırlandırılması gerektiğini belirtir. Bu, ilişkisel veritabanlarının temel bir özelliğidir ve bağlantısız tablo koleksiyonunu zengin örtüşen ilişkilere sahip olacak şekilde dönüştüren "yapıştırıcıdır".

İlişki () olarak bilinen ikinci bir yönerge, ORM'ye, Invoice sınıfının Invoice.customer özelliği kullanılarak Müşteri sınıfına bağlanması gerektiğini söyler. İlişki (), bu bağlantının doğasını belirlemek için iki tablo arasındaki yabancı anahtar ilişkilerini kullanır ve çoktan bire olduğunu belirler.

Customer.invoices özelliği altında Müşteri eşlenen sınıfına ek bir ilişki () yönergesi yerleştirilir. İlişki.back_populates parametresi, tamamlayıcı öznitelik adlarına başvurmak üzere atanır, böylece her ilişki (), ters olarak ifade edilen aynı ilişki hakkında akıllı kararlar verebilir. Bir tarafta, Invoices.customer, Invoices örneğini, diğer tarafta Customer.invoices, Müşteri örneklerinin bir listesini ifade eder.

İlişki işlevi, SQLAlchemy ORM paketinin İlişki API'sinin bir parçasıdır. İki eşlenmiş sınıf arasında bir ilişki sağlar. Bu, bir ebeveyn-çocuk veya ilişkisel tablo ilişkisine karşılık gelir.

Bulunan temel İlişki Modelleri aşağıdadır -

Birden çoğa

Bire Çok ilişkisi, alt tablodaki yabancı anahtar yardımıyla ebeveyne atıfta bulunur. ilişki (), alt öğe tarafından temsil edilen bir öğe koleksiyonuna atıfta bulunarak üst öğe üzerinde belirtilir. Communication.back_populates parametresi, "ters" tarafın çoka bir olduğu bire çokta çift yönlü bir ilişki kurmak için kullanılır.

Çoktan bire

Öte yandan, Çoktan Bire ilişkisi, çocuğa başvurmak için ana tabloya bir yabancı anahtar yerleştirir. ilişki (), yeni bir skaler tutma özniteliğinin yaratılacağı üst öğe üzerinde bildirilir. Burada yine Bidirectionalbehaviour için communication.back_populates parametresi kullanılır.

Bire bir

Bire Bir ilişki, esasen doğada çift yönlü bir ilişkidir. Uselist bayrağı, ilişkinin "çok" tarafındaki bir koleksiyon yerine bir skaler özniteliğin yerleşimini belirtir. Birden çoka bire bir ilişki türüne dönüştürmek için uselist parametresini false olarak ayarlayın.

Çoktan çoğa

Çoktan çoğa ilişkisi, yabancı anahtarları ile öznitelikleri tanımlayarak iki sınıfla ilgili bir ilişki tablosu eklenerek kurulur. İlişki () için ikincil argüman ile belirtilir. Tablo genellikle bildirim temelli temel sınıfla ilişkili MetaData nesnesini kullanır, böylece ForeignKey yönergeleri bağlanacak uzak tabloları bulabilir. İlişki.back_populates parametresi, her ilişki () için çift yönlü bir ilişki kurar. İlişkinin her iki tarafı da bir koleksiyon içerir.