如何为具有共享架构和动态名称的多个表动态创建 Django 模型?

DDD
发布: 2024-10-25 01:42:30
原创
258 人浏览过

How can Django models be dynamically created for multiple tables with shared schemas and dynamic names?

在 Django 中为多个表创建动态模型

对于保存大量具有共享架构和动态名称的临时表的数据库,集成 Django 带来了挑战。但是,可以使用工厂函数创建具有动态数据库表的模型。

动态数据库表管理

工厂函数返回具有指定数据库的模型桌子。这允许基于表名称进行动态数据绑定:

<code class="python">def getModel(db_table):
  class MyClass(models.Model):
    # Model definition goes here...
    class Meta:
      db_table = db_table
  return MyClass</code>
登录后复制

然后您可以使用特定表名称实例化模型:

<code class="python">newClass = getModel('29345794_table')
newClass.objects.filter(...)</code>
登录后复制

用于动态类命名的元类

由于 Django 缓存了类的 _meta 属性,因此需要一个元类来在运行时修改类名:

<code class="python">def getModel(db_table):
  class MyClassMetaclass(models.base.ModelBase):
    def __new__(cls, name, bases, attrs):
      name += db_table
      return models.base.ModelBase.__new__(cls, name, bases, attrs)

  class MyClass(models.Model):
    __metaclass__ = MyClassMetaclass
    class Meta:
      db_table = db_table
  return MyClass</code>
登录后复制

其他注意事项

虽然最初认为是不可变的,但数据库表可以动态设置:

<code class="python">MyModel._meta.db_table = '10293847_table'</code>
登录后复制

以上是如何为具有共享架构和动态名称的多个表动态创建 Django 模型?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!