在 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中文网其他相关文章!