为了处理不断增长的数据库表,我们正在分片表名.所以我们可以使用如下命名的数据库表:
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是映射到表的类.