Création de modèles dynamiques pour plusieurs tables dans Django
Pour une base de données contenant de nombreuses tables temporaires avec des schémas partagés et des noms dynamiques, l'intégration de Django présente des défis . Cependant, il est possible d'utiliser une fonction d'usine pour créer des modèles avec des tables de base de données dynamiques.
Gestion dynamique des tables de base de données
La fonction d'usine renvoie un modèle avec une base de données spécifiée tableau. Cela permet une liaison de données dynamique basée sur les noms de table :
<code class="python">def getModel(db_table): class MyClass(models.Model): # Model definition goes here... class Meta: db_table = db_table return MyClass</code>
Vous pouvez ensuite instancier le modèle avec le nom de table spécifique :
<code class="python">newClass = getModel('29345794_table') newClass.objects.filter(...)</code>
Métaclasse pour la dénomination dynamique des classes
Étant donné que Django met en cache l'attribut _meta de la classe, une métaclasse est nécessaire pour modifier le nom de la classe au moment de l'exécution :
<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>
Considérations supplémentaires
Bien qu'initialement considérée comme immuable, la table de la base de données peut être définie dynamiquement :
<code class="python">MyModel._meta.db_table = '10293847_table'</code>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!