Я намагаюся зрозуміти, як розподілити класи SQLAlchemy по кількох файлах, і я за все життя не можу зрозуміти, як це зробити. Я дуже новачок у SQLAlchemy, тому пробачте мене, якщо це питання є тривіальним
Розглянемо ці 3 класи в кожному з них власним файлом :
A.py:
from sqlalchemy import *
from main import Base
class A(Base):
__tablename__ = "A"
id = Column(Integer, primary_key=True)
Bs = relationship("B", backref="A.id")
Cs = relationship("C", backref="A.id")
B.py:
from sqlalchemy import *
from main import Base
class B(Base):
__tablename__ = "B"
id = Column(Integer, primary_key=True)
A_id = Column(Integer, ForeignKey("A.id"))
C.py:
from sqlalchemy import *
from main import Base
class C(Base):
__tablename__ = "C"
id = Column(Integer, primary_key=True)
A_id = Column(Integer, ForeignKey("A.id"))
А потім скажіть, що у нас main.py приблизно такий:
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relationship, backref, sessionmaker
Base = declarative_base()
import A
import B
import C
engine = create_engine("sqlite:///test.db")
Base.metadata.create_all(engine, checkfirst=True)
Session = sessionmaker(bind=engine)
session = Session()
a = A.A()
b1 = B.B()
b2 = B.B()
c1 = C.C()
c2 = C.C()
a.Bs.append(b1)
a.Bs.append(b2)
a.Cs.append(c1)
a.Cs.append(c2)
session.add(a)
session.commit()
Вищезазначене дає помилку:
sqlalchemy.exc.NoReferencedTableError: Foreign key assocated with column 'C.A_id' could not find table 'A' with which to generate a foreign key to target column 'id'
Як поділитися декларативною базою між цими файлами?
Що таке «правильний» спосіб зробити це, з огляду на , що я міг би кинути що - щось на зразок Пілони або Turbogears на вершині цього?
редагувати 10-03-2011
Я знайшов цей опис із фреймворку Pyramids, який описує проблему і, що ще важливіше, підтверджує, що це справжня проблема, а не (лише) лише моя розгублена суть, в якій проблема. Сподіваюся, це може допомогти іншим, хто наважиться на цю небезпечну дорогу :)