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

Symfony PHP Discussion :

Suppression d'une entité (association) avec une clé primaire composée


Sujet :

Symfony PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2018
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2018
    Messages : 6
    Par défaut Suppression d'une entité (association) avec une clé primaire composée
    Bonjour,

    Je réalise une application pour mon stage: appels d'offre fournisseur.

    J'ai une entité Provider, une entité CallOfOffer et une entité (association) ConsultAndOffer dont la clé est composée des clés étrangères provider_id et call_of_offer_id

    Lorsque je souhaite supprimer une proposition faite par un fournisseur concernant un appel d'offre, j'ai sur symfony le message d'erreur suivant:
    Binding an entity with a composite primary key to a query is not supported...
    Je m'apperçoit que dans PhpMyAdmin, je n'ai pas non plus la possibilité de supprimer une entrée individuellement (truncate fonctionne pour vider la table), je n'ai pas de bouton Supprimer : je suppose que c'est un problème d'identifiant, car la commande DELETE a besoin d'un id et là j'en ai deux.

    Pourriez vous me donner une solution à ce problème s'il vous plaît, je n'ai pas encore trouvé malgré mes recherches avec cette erreurs.
    Il faut décomposer, certes, mais comment? et pourquoi est-ce impossible dans phpmyadmin il n'y a pourtant pas de contrainte par rapport aux deux autres tables???

    Merci de votre aide.

    Phil

  2. #2
    Membre Expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 59
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Billets dans le blog
    8
    Par défaut
    Tu peux nous détailler tes tables SQL et leur relation ? Quitte à faire un export SQL...
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2018
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2018
    Messages : 6
    Par défaut mes tables :
    Nom : CallOfOffer.png
Affichages : 1334
Taille : 21,2 KoNom : ConsultAndOffer.png
Affichages : 1263
Taille : 9,6 KoNom : Provider  (extends User).png
Affichages : 1246
Taille : 3,3 KoNom : User.png
Affichages : 1312
Taille : 16,3 Ko

    Je voudrais supprimer les entrées de ConsultAndOffer et ce n'est pas possible via PhpMyAdmin à cause du DELETE(id) je présume et comme c'est une association ben y'en a 2 des clés étrangères...Je suis assez débutant sous symfo. On me dit de spliter mais comment? je ne vois pas du tout....

    Merci à vous

  4. #4
    Membre Expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 59
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Billets dans le blog
    8
    Par défaut
    Ce n'est probablement pas un problème symfony, puisque tu dis que phpmyadmin te bloque.
    C'est probablement une clé étrangère, pas sur la table ConsultAndOffer, mais sur une des 2 autres tables liées ou les 2, qui "on delete" bloque tout, tandis que tu sembles vouloir un "on delete CASCADE"...
    Il faut donc que tu nous exportes le SQL de ta base.
    export / structure seule / SQL

    Je te donne un exemple simple :

    Tu as une table departement, puis tu as une table ville. La table ville contient bien sûr une clé étrangère vers departement via departement_id.
    Si tu veux supprimer une ville, aucun problème.
    Mais que veux-tu qu'il se passe si l'on détruit tout un département ? Que ça supprime toutes les villes de CE département en cascade, ou bien que ça t'interdise de supprimer un département tant qu'au moins une ville y est affectée ?
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  5. #5
    Membre Expert
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2012
    Messages
    631
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2012
    Messages : 631
    Par défaut
    Lorsque je souhaite supprimer une proposition faite par un fournisseur concernant un appel d'offre, j'ai sur symfony le message d'erreur suivant:
    Binding an entity with a composite primary key to a query is not supported...
    les 2 clés ne sont pas supportées par doctrine car la stratégie de génération de tes clés dans l'entité est soit absente soit à @ORM\GeneratedValue(strategy="NONE"), donc tes clés sont gérées par ton application.Dans ce cas pour supprimer, tu fais appelle à la focntion doctrine IDENTITY
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    //dans la repository de l'entité CallOfOffer
     $query = $this->createQueryBuilder( 'co' )
                ->delete()
                ->where('IDENTITY(co.callOfOffer) =:callOfferId') // nom de la proprieté dans CallOfOffer
                ->andWhere('IDENTITY(co.provide) =:provideId' )  // nom de la proprieté dans CallOfOffer
               ->setParameters( ['callOfferId' => 1, 'provideId' => 3 ]);
                ->getQuery()->getResult();

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2018
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2018
    Messages : 6
    Par défaut suite
    Merci à vous deux, c'est très sympa de répondre aussi vite et ça me permet de progresser, mais ça ne fonctionne pas malgré toutes mes tentatives...en dernier ressors j'ai essayé cela:
    Nom : 1.png
Affichages : 1202
Taille : 7,0 Ko
    et voilà la même erreur
    Nom : 2.png
Affichages : 1200
Taille : 11,2 Ko

    JE suis désolé je peine, pas doué et pourtant je cherche depuis un moment

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 0
    Dernier message: 08/04/2013, 11h58
  2. Réponses: 0
    Dernier message: 23/12/2010, 16h39
  3. Réponses: 18
    Dernier message: 26/11/2007, 15h43
  4. Réponses: 9
    Dernier message: 15/03/2007, 00h02
  5. copie d'une table Y d'une base A vers une table X d'une base
    Par moneyboss dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 30/08/2005, 21h24

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