"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment créer dynamiquement des modèles Django pour plusieurs tables avec des schémas partagés et des noms dynamiques ?

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

Publié le 2024-11-04
Parcourir:936

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 :

def getModel(db_table):
  class MyClass(models.Model):
    # Model definition goes here...
    class Meta:
      db_table = db_table
  return MyClass

Vous pouvez ensuite instancier le modèle avec le nom de table spécifique :

newClass = getModel('29345794_table')
newClass.objects.filter(...)

Métaclasse pour la dénomination dynamique des classes

Puisque 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 :

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

Considérations supplémentaires

Bien qu'initialement considérée comme immuable, la table de base de données peut être définie dynamiquement :

MyModel._meta.db_table = '10293847_table'
Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3