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'
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