Maison > base de données > tutoriel mysql > le corps du texte

Comment créer dynamiquement des modèles Django pour plusieurs tables avec des schémas partagés et des noms dynamiques ?

DDD
Libérer: 2024-10-25 01:42:30
original
258 Les gens l'ont consulté

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

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>
Copier après la connexion

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>
Copier après la connexion

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>
Copier après la connexion

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>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!