python – 在SQLAlchemy中动态设置__tablename__来分片?

为了处理不断增长的数据库表,我们正在分片表名.所以我们可以使用如下命名的数据库表:

table_md5one
table_md5two
table_md5three

所有表具有完全相同的模式.

我们如何使用SQLAlchemy并动态指定与此对应的类的tablename?看来,declarative_base()类需要预先指定tablename.

最终会有太多的表从父/基类手动指定派生类.我们希望能够构建一个能够使tablename动态设置的类(可以作为一个参数传递给一个函数).

解决方法

好的,我们使用了自定义的SQLAlchemy声明,而不是声明式的声明.

所以我们创建一个这样的动态表对象:

from sqlalchemy import MetaData,Table,Column

def get_table_object(self,md5hash):
    metadata = MetaData()
    table_name = 'table_' + md5hash
    table_object = Table(table_name,metadata,Column('Column1',DATE,nullable=False),Column('Column2',nullable=False)
    )
    clear_mappers()
    mapper(ActualTableObject,table_object)
    return ActualTableObject

其中ActualTableObject是映射到表的类.

dawei

【声明】:丽水站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

相关文章