IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Django Python Discussion :

Problème d'héritage dans mes modèles


Sujet :

Django Python

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Octobre 2019
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2019
    Messages : 39
    Points : 28
    Points
    28
    Par défaut Problème d'héritage dans mes modèles
    Bonjour,

    Je suis débutant sur django et bute sur un problème d'héritage entre models que j'aimerais mettre en place.
    Voici mes modèles:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
    class Interaction(models.Model):
        nom = models.CharField(max_length=128, unique=True)
        lieu = models.ForeignKey(Lieu, on_delete=models.CASCADE, blank=True, null=True)
        description = models.TextField(default='...')
        acces_libre = models.BooleanField(default=True)
     
     
    class Heros(Interaction):
        user = models.ForeignKey(User, on_delete=models.CASCADE, blank=True,null=True)
     
        #############   Attributs   ##########
        corps = models.IntegerField(default=0)
        coeur = models.IntegerField(default=0)
        esprit = models.IntegerField(default=0)
     
     
        def __str__(self):
            return self.nom
     
     
    class Personnage(Interaction):
     
        # Attributs  
        corps = models.IntegerField(default=50)
        coeur = models.IntegerField(default=50)
        esprit = models.IntegerField(default=50)
     
     
        def __str__(self):
            return self.nom
    Et voici le résultat de ma migration:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
     
    migrations.CreateModel(
                name='Interaction',
                fields=[
                    ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                    ('nom', models.CharField(max_length=128, unique=True)),
                    ('description', models.TextField(default='...')),
                    ('acces_libre', models.BooleanField(default=True)),
                ],
            ),
     
    migrations.CreateModel(
                name='Heros',
                fields=[
                    ('interaction_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='aventures.Interaction')),
                    ('corps', models.IntegerField(default=0)),
                    ('coeur', models.IntegerField(default=0)),
                    ('esprit', models.IntegerField(default=0)),
                    ('user', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
                ],
                bases=('aventures.interaction',),
            ),
     
    migrations.CreateModel(
                name='Personnage',
                fields=[
                    ('interaction_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='aventures.Interaction')),
                    ('corps', models.IntegerField(default=50)),
                    ('coeur', models.IntegerField(default=50)),
                    ('esprit', models.IntegerField(default=50)),
                ],
                bases=('aventures.interaction',),
            ),
    migrations.AddField(
                model_name='interaction',
                name='lieu',
                field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='aventures.Lieu'),
            ),
    Il me semble que tout est correct et que le lien par clé étrangère se fait bien... cependant lorsque je souhaite créer une instance de héros sur l'interface admin, j'obtiens:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    no such column: aventures_heros.interaction_ptr_id
    Lorsque je souhaite créer une instance Personnage:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    no such table: aventures_personnage
    J'ai vidé mon dossier migration, supprimer toutes les instances d'avant mon changement dans les modèles, rien ne change...

    Auriez-vous une idée?

    Merci à vous.
    Niko

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 283
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 283
    Points : 36 770
    Points
    36 770
    Par défaut
    Salut,

    Citation Envoyé par Niko21 Voir le message
    Auriez-vous une idée?
    Derrière ce genre d'héritage, il y a les tables d'un SGDB et si plusieurs tables il y a une relation a définir entre elles.
    C'est compliqué! Il faut prendre le temps de comprendre ce que raconte la documentation Django sur le sujet et réfléchir au modèle de données (le côté SGDB) avant.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Octobre 2019
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2019
    Messages : 39
    Points : 28
    Points
    28
    Par défaut
    Bonjour,

    Ok merci pour votre réponse, je vais essayer de potasser tout ça.

Discussions similaires

  1. problème de modélisation dans un modèle eav
    Par matN59 dans le forum Développement de jobs
    Réponses: 0
    Dernier message: 31/10/2008, 13h26
  2. Problèmes d'espaces dans mes résultat de requète
    Par Stouille89 dans le forum JDBC
    Réponses: 4
    Dernier message: 23/04/2008, 12h25
  3. Problème de code dans mes formulaires
    Par domgrondin dans le forum IHM
    Réponses: 4
    Dernier message: 08/06/2007, 18h08
  4. Problèmes d'espaces dans mes entrées
    Par Sanka76 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 12/02/2007, 09h35
  5. problème d'apostrophe dans mes requetes
    Par kirian dans le forum Bases de données
    Réponses: 3
    Dernier message: 03/05/2006, 12h06

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo