python sqlalchemy动态修改tablename两种实现方式
方式一
在Python的SQLAlchemy ORM中,您可以使用以下代码动态地更改数据模型类的表名:
from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() class MyModel(Base): __tablename__ = 'my_custom_table_name' id = Column(Integer, primary_key=True) name = Column(String) age = Column(Integer) #... 其它定义或使用... # 动态修改表名 MyModel.__table__.name = 'my_new_table_name'
在这个例子中,我们首先定义了一个名为MyModel
的数据模型,并将其与my_custom_table_name
表相关联。然后,在必要时,我们可以通过访问模型类的__table__
属性来动态地更改表名。
这是因为ORM框架本身会自动为每个数据模型类创建一个对应的Table对象,并将其存储在该类的__table__
属性中。我们可以使用name
属性直接更新此对象的名称,从而实现动态更改表名的目的。
请注意,动态更改表名可能会影响到您的应用程序的正确性和可维护性。因此,请考虑清楚是否真正需要这样做,以及如何规划数据库模式的变化。
方式二
如果我们原先的class为此:
from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() class MyModel(Base): __tablename__ = 'my_custom_table_name' id = Column(Integer, primary_key=True) name = Column(String) age = Column(Integer)
我们可以定义其抽象类:
class MyModelCls(Base): __abstract__ = True # 关键语句,定义所有数据库表对应的父类 __table_args__ = {"extend_existing": True} # 允许表已存在 id = Column(Integer, primary_key=True) name = Column(String) age = Column(Integer)
然后通过函数返回class对象
def get_source_data_model_cls(cid, cid_class_dict={}): if cid not in cid_class_dict: cls_name = table_name = cid cls = type(cls_name, (MyModelCls, ), {'__tablename__': table_name}) cid_class_dict[cid] = cls return cid_class_dict[cid]
到此这篇关于python sqlalchemy动态修改tablename两种实现方式的文章就介绍到这了,更多相关python sqlalchemy动态修改tablename内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
python paramiko利用sftp上传目录到远程的实例
今天小编就为大家分享一篇python paramiko利用sftp上传目录到远程的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-01-01python向已存在的excel中新增表,不覆盖原数据的实例
下面小编就为大家分享一篇python向已存在的excel中新增表,不覆盖原数据的实例,具有很好超参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-05-05python获取指定日期范围内的每一天,每个月,每季度的方法
这篇文章主要介绍了python获取指定日期范围内的每一天,每个月,每季度的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-08-08利用Python实现K-Means聚类的方法实例(案例:用户分类)
k-means是发现给定数据集的k个簇的算法,也就是将数据集聚合为k类的算法,下面这篇文章主要给大家介绍了关于利用Python实现K-Means聚类的相关资料,需要的朋友可以参考下2022-05-05Python 通过微信控制实现app定位发送到个人服务器再转发微信服务器接收位置信息
这篇文章主要介绍了Python 通过微信控制实现app定位发送到个人服务器,再转发微信服务器接收位置信息,本文给出了实例代码,代码简单易懂,非常不错具有一定的参考借鉴价值,需要的朋友可以参考下2019-08-08
最新评论