Ако искате много актьори да бъдат свързани с един филм и много филми да бъдат свързани с един актьор, вие искате много към много. Това означава, че имате нужда от асоциативна таблица. В противен случай можете да изхвърлите нормализацията и да използвате NoSQL база данни.
Решение за асоциативна таблица може да прилича на:
class Actor(Base):
__tablename__ = 'actors'
id = Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
name = Column(String)
nickname = Column(String)
academy_awards = Column(Integer)
class Movie(Base):
__tablename__ = 'movies'
id = Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
title = Column(String)
actors = relationship('ActorMovie', uselist=True, backref='movies')
class ActorMovie(Base):
__tablename__ = 'actor_movies'
actor_id = Column(UUID(as_uuid=True), ForeignKey('actors.id'))
movie_id = Column(UUID(as_uuid=True), ForeignKey('movies.id'))
Ако не искате ActorMovie да бъде обект, наследяващ от Base, можете да използвате sqlachlemy.schema.Table
.