我有两张桌子,image
和restaurant
。我已经在它们之间建立了多对多的关系。
以下是表定义的相关部分:
images_assoc = Table('restaurant_image_assoc', Base.metadata,
Column('restaurant', Integer(unsigned=True),
ForeignKey('restaurant.id')),
Column('image', Integer(unsigned=True),
ForeignKey('image.id')))
class Image(Base):
__tablename__ = 'image'
id = Column(Integer(unsigned=True), primary_key=True)
reports = Column(TinyInt, nullable=False, default=0)
created_at = Column(DateTime, default=datetime.now)
class Restaurant(Base):
__tablename__ = 'restaurant'
id = Column(Integer(unsigned=True), primary_key=True)
images = relationship(Image, secondary=images_assoc)
我需要删除 中的一行,但当然我需要先删除指向它image
的所有行。restaurant_image_assoc
我该怎么做呢?
我试过这个:
request.db.query(images_assoc)\
.filter(images_assoc.c.image==image.id).delete()
request.db.delete(image)
request.db.commit()
image
我要删除的行在哪里,但出现此错误:
AttributeError: 'Table' object has no attribute 'class_'