python – 在SQLAlchemy中动态设置__tablename__来分片?
发布时间:2021-01-11 11:46:37 所属栏目:Python 来源:互联网
导读:为了处理不断增长的数据库表,我们正在分片表名.所以我们可以使用如下命名的数据库表: table_md5onetable_md5twotable_md5three 所有表具有完全相同的模式. 我们如何使用SQLAlchemy并动态指定与此对应的类的tablename?看来,declarative_base()类需要预先指定
为了处理不断增长的数据库表,我们正在分片表名.所以我们可以使用如下命名的数据库表: 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是映射到表的类. (编辑:鲜蔬坊站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- 有没有办法找出文件的名称stdout被重定向到Pytho
- pyDes 实现 Python 版的 DES 对称加密/解密--转
- python – 从scipy.stats … rvs和numpy.random的
- [Python] 函数基本
- django – formfield_for_foreignkey和内联管理员
- 为什么python设计为str(无)返回’None’而不是空
- python – 请求 – 总是调用raise_for_status
- python – 如何在selenium webdriver中使用变量通
- python – 填充OpenCV轮廓的外部
- python – 如何覆盖BaseHTTPRequestHandler log_
热点阅读