Sqlalchemy声明性继承__

2024-05-19 02:09:55 发布

您现在位置:Python中文网/ 问答频道 /正文

假设我有这样的桌子

class Base(object):
    id = Column(Integer, primary_key=True)
    date_updated = Column(Date, nullable=True)
    rating = Column(Integer, nullable=False, default=0)
    status = Column(SmallInteger, nullable=False, default=0)

    @declared_attr
    def __tablename__(cls):
        return "table_%s" % cls.LANG

    @declared_attr
    def __table_args__(cls):
        return (
            Index('ix__%s__rating' % cls.__tablename__, 'rating'),
            Index(
                'ix__%s__status' % cls.__tablename__,
                'status',
                postgresql_where=column('status') == 0,
            ),
            Index(
                'ix__%s__date_updated' % cls.__tablename__,
                'date_updated',
                postgresql_where=column('date_updated') != None,
            ),
        )

   class TableEn(Base, db.Model):
       LANG = 'en'


   class TableUk(Base, db.Model):
       LANG = 'uk'

我发现了如何在父级__table_args__中创建status和{}这样的(部分)索引。在

但是我需要创建desc排序索引rating,比如func.desc(rating),但我不知道如何做到这一点。在

没有一个变体适合我(变体和它的错误):

  • Index('ix__%s__rating' % cls.__tablename__, 'rating desc')

    键错误:“评级说明”

  • Index('ix__%s__rating' % cls.__tablename__, cls.rating.desc())

    sqlalchemy.exc.ArgumentError:无法将未命名列添加到列集合中

  • Index('ix__%s__rating' % cls.__tablename__, desc('rating'))

    在数据库中创建架构时

    sqlalchemy.exc.ProgrammingError:(ProgrammingError)语法错误位于或接近“)” 第1行:在table\u en()上创建索引ix_Uutable_en_urating

当然,我可以用directsql手动创建索引,但我确信在某个地方存在解决方案。在

提前谢谢!在


Tags: langbasedateindexstatustablecolumndesc
1条回答
网友
1楼 · 发布于 2024-05-19 02:09:55

以下是简化的代码:

class BaseModel(Base):

    __abstract__ = True

    id = Column(Integer, primary_key=True)
    rating = Column(Integer, nullable=False, default=0)

    @declared_attr
    def __tablename__(cls):
        return "table_%s" % cls.LANG

    @classmethod
    def build_indexes(cls):
        Index('ix__%s__rating' % cls.__tablename__, cls.__table__.c.rating.desc())


@event.listens_for(BaseModel, 'instrument_class', propagate=True)
def receive_mapper_configured(mapper, class_):
    class_.build_indexes()


class TableEn(BaseModel):
   LANG = 'en'


class TableUk(BaseModel):
   LANG = 'uk'

完整代码here。在

你有两个问题。首先,应该对表列调用desc,而不是映射器对象属性。但如果您这样做了,那么填充就有问题,因为__table__属性是在从__table__args__获取信息后创建的。所以您需要在创建__table__字段之后创建索引。一种方法是通过sqlalchemy事件。在

相关问题 更多 >

    热门问题