首页 > 脚本专栏 > python > python sqlalchemy动态修改tablename

python sqlalchemy动态修改tablename两种实现方式

作者:拾牙慧者

这篇文章主要介绍了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中xmltodict对xml的操作方式
    Python中xmltodict对xml的操作方式
    2023-03-03
  • 基于Python实现模拟三体运动的示例代码
    基于Python实现模拟三体运动的示例代码
    2023-03-03
  • 如何使用python统计字符在文件中出现的次数
    如何使用python统计字符在文件中出现的次数
    2023-03-03
  • np.concatenate()函数数组序列参数的实现
    np.concatenate()函数数组序列参数的实现
    2023-03-03
  • Python之ThreadPoolExecutor线程池问题
    Python之ThreadPoolExecutor线程池问题
    2023-03-03
  • python sqlalchemy动态修改tablename两种实现方式
    python sqlalchemy动态修改tablename两种实
    2023-03-03
  • np.ones的使用小结
    np.ones的使用小结
    2023-03-03
  • python中小数点后的位数问题
    python中小数点后的位数问题
    2023-03-03
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2023 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号