在SQLAlchemy中关联多对多关系的对象

2 投票
1 回答
2598 浏览
提问于 2025-04-17 16:28

我正在尝试通过SQLAlchemy将两个数据库对象关联起来,使用的是双向的多对多关系。我需要在一个连接表中建立这种关联。相关的表和数据已经存在于一个SQLite3数据库中。

下面是一个简单的例子。

Base = declarative_base()

class Colour (Base):
    __tablename__ = 'colours'
    id = Column("id", Integer, primary_key=True)
    name = Column("name", String)
    vehicles = association_proxy('vehicles_and_colours', 'vehicles')

class Vehicle (Base):
    __tablename__ = 'vehicles'
    id = Column("id", Integer, primary_key=True)
    name = Column("name", String)
    colours = association_proxy('vehicles_and_colours', 'colours')

class ColourVehicle (Base):
    __tablename__ = 'vehicles_and_colours'
    colour_id = Column('colour_fk', Integer, ForeignKey('colours.id'), primary_key=True)
    vehicle_id = Column('vehicle_fk', Integer, ForeignKey('vehicles.id'), primary_key=True)

    colours = relationship(Colour, backref=backref("vehicles_and_colours"))
    vehicles = relationship(Vehicle, backref=backref("vehicles_and_colours"))

blue = session.query(Colour).filter(Colour.name == "blue").first()
car = session.query(Vehicle).filter(Vehicle.name == "car").first()

blue.vehicles.append(car)

这段代码给我带来了错误:

  File "/usr/local/lib/python2.6/dist-packages/SQLAlchemy-0.8.0b2-py2.6-linux-i686.egg/sqlalchemy/ext/associationproxy.py", line 554, in append
    item = self._create(value)
  File "/usr/local/lib/python2.6/dist-packages/SQLAlchemy-0.8.0b2-py2.6-linux-i686.egg/sqlalchemy/ext/associationproxy.py", line 481, in _create
    return self.creator(value)
TypeError: __init__() takes exactly 1 argument (2 given)

我哪里做错了呢?

1 个回答

3

关联代理需要目标对象有一个只接受一个参数的构造函数,这样才能创建合适的中介对象,或者需要指定一个 creator,来说明如何创建一个 ColorVehicle:

vehicles = association_proxy('vehicles_and_colours', 'vehicles', 
                creator=lambda vehicle: ColorVehicle(vehicle=vehicle))

colours = association_proxy('vehicles_and_colours', 'colours', 
               creator=lambda color: ColorVehicle(color=color))

这部分内容有详细的说明:

https://docs.sqlalchemy.org/en/latest/orm/extensions/associationproxy.html#creation-of-new-values

撰写回答