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

C++/CLI Discussion :

L'instruction INSERT est en conflit avec la contrainte FOREIGN KEY SAME TABLE


Sujet :

C++/CLI

  1. #1
    Débutant
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2008
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 022
    Points : 332
    Points
    332
    Par défaut L'instruction INSERT est en conflit avec la contrainte FOREIGN KEY SAME TABLE
    bonjour,
    J'ai un phénomène inquiétant:
    J'ai le message T_SEG_CHUNK_FK1". Le conflit s'est produit dans la base de données "COHERENCE", table "dbo.T_SEG_CHUNK", column 'nuIdSegChk'.
    L'instruction a été arrêtée
    qui m'est jetté à la figure sur l'enregistrement 77 pour nuIdSegChk
    Je peux faire l'insert avec SSMSM:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SET IDENTITY_INSERT [T_SEG_CHUNK] ON
    INSERT INTO T_SEG_CHUNK ( nuIdSegChk, nuIdSeg, nuIdChunk, iInitPos, nuIdPrev, cAlignStatus) VALUES ( 77, 15, 53, 6, NULL, 3)
    sans que j'ai un signe de mauvais enregistrement
    et le programme se plante sur la même requête
    celui qui m'éclairera sera

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 379
    Points : 41 573
    Points
    41 573
    Par défaut
    On n'a pas la définition des tables, ni la définition de la contrainte qui pète, ni même quel SGBD tu utilises...

    Mais en gros, ta contrainte semble chercher un enregistrement dont une des valeurs (nuIdChk peut-être?) est égale à la valeur que tu donnes pour nuIdSegChk (ici, 77).
    Et pète parce que ça n'en trouve pas.

  3. #3
    Débutant
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2008
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 022
    Points : 332
    Points
    332
    Par défaut je réponds point par point
    et merci pour ta réaction rapide
    Le SGBD est de microsoft SQL Server
    la table est ci_dessous
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    T_SEG_CHUNK (
      nuIdSegChk NUMERIC(18,0) not null identity,
      nuIdSeg NUMERIC(18,0) not null,
      nuIdChunk NUMERIC(18,0) not null,
      iInitPos INTEGER not null constraint T_SEG_CHUNKiInitPos_Chk check (iInitPos >= 1) ,
      nuIdPrev NUMERIC(18,0),
      nuIdNext NUMERIC(18,0),
      cMatchStatus CHAR(1) constraint T_SEG_CHUNKcMatchStatus_Chk check ( (cMatchStatus between '0' and '4')  OR (cMatchStatus IS NULL) ) ,
      cAlignStatus CHAR(1) constraint T_SEG_CHUNKcAlignStatus_Chk check ( (cAlignStatus between '0' and '5')  OR (cAlignStatus IS NULL) ) , constraint T_SEG_CHUNK_PK primary key (nuIdSegChk) );

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 144
    Points : 12 250
    Points
    12 250
    Par défaut
    Et la définition de "T_SEG_CHUNK_FK1" dans la base? SVP ? (indice: une clé étrangère)

  5. #5
    Débutant
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2008
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 022
    Points : 332
    Points
    332
    Par défaut je répond
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    alter table T_SEG_CHUNK
      add constraint T_CHUNK_FK1 foreign key (
        nuIdChunk)
       references T_CHUNK (
        nuIdChunk);

  6. #6
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 379
    Points : 41 573
    Points
    41 573
    Par défaut
    Ben pourquoi as-tu écrit "FOREIGN KEY SAME TABLE" dans le titre alors?
    Le texte que tu as posté montre une FK de T_SEG_CHUNK à T_CHUNK...

  7. #7
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 144
    Points : 12 250
    Points
    12 250
    Par défaut
    Il faut qu'un enregistrement dans la table "T_CHUNK" ait la valeur "53" dans la colonne "nuIdChunk", car vous voulez ajouter un enregistrement dans la table "T_SEG_CHUNK" avec comme valeur de la colonne "nuIdChunk" égale à 53.
    (Ne pas confondre la colonne "nuIdChunk" de la table "T_CHUNK" et la colonne "nuIdChunk" de la table "T_SEG_CHUNK".)
    De la base de données SQL de base, donc si c'est nébuleux pour vous, je vous invite à lire un cours sur les bases de données relationnelles et en particuliers les clés étrangères.

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

Discussions similaires

  1. [2008] Instruction insert en conflit avec la contrainte foreign key
    Par bza88 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 14/11/2014, 12h03
  2. [2012] Problème de conflit d'ALTER TABLE avec la contrainte FOREIGN KEY
    Par Caliimero dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 15/03/2014, 19h03
  3. La clause ORDER BY est en conflit avec le DISTINCT
    Par azertix dans le forum Langage SQL
    Réponses: 7
    Dernier message: 26/06/2008, 15h24
  4. Erreur: conflit avec la contrainte FOREIGN KEY SAME TABLE
    Par useretl dans le forum Langage SQL
    Réponses: 2
    Dernier message: 25/10/2007, 12h27
  5. Réponses: 2
    Dernier message: 31/07/2007, 15h53

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