gpt4 book ai didi

python - Flask-SQLAlchemy create_all 如何发现要创建的模型?

转载 作者:太空狗 更新时间:2023-10-29 20:40:41 27 4
gpt4 key购买 nike

Flask-SQLAlchemy 的 db.create_all() 方法创建与我定义的模型相对应的每个表。我从不实例化或注册模型的实例。它们只是继承自 db.Model 的类定义。它怎么知道我定义了哪些模型?

最佳答案

Flask-SQLAlchemy 没有什么特别之处,它都是 SQLAlchemy 的标准部分。

调用 db.create_all最终调用 db.Model.metadata.create_all .表格是 associated with a MetaData instance as they are defined .在 SQLAlchemy 中,确切的机制非常迂回,因为有很多幕后簿记在进行,所以我大大简化了解释。

db.Model 是一个 declarative base class ,它有一些特殊的元类行为。当它被定义时,它会在内部创建一个 MetaData 实例来存储它为模型生成的表。当您子类化 db.Model 时,它的元类行为记录 db.Model._decl_class_registry 中的类以及 db.Model.metadata 中的表>.


类仅在导入包含它们的模块时定义。如果你有一个模块 my_models 写在某处,但它从未被导入,它的代码永远不会执行,所以模型永远不会被注册。

这可能是关于 SQLAlchemy 如何检测模型的一些混淆的来源。没有为子类“扫描”模块,未使用 db.Model.__subclasses__,但代码执行需要在某处导入模块

  1. 导入并执行包含模型的模块。
  2. 模型类定义被执行,子类db.Model
  3. 模型的表已注册到 db.Model.metadata

关于python - Flask-SQLAlchemy create_all 如何发现要创建的模型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31082692/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com