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

Requêtes MySQL Discussion :

Contrainte d'intégrité en INSERT


Sujet :

Requêtes MySQL

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 41
    Points : 35
    Points
    35
    Par défaut Contrainte d'intégrité en INSERT
    Bonjour,

    Je travaille sur une base mysql V5 avec une table "enfant" ayant des clés etrangères sur des tables "parents" de la façon suivante (exemple):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    alter table SUIVI_D_UN_DOSSIER 
    add constraint FK_REFERENCE_7 foreign key (CODE_ASSISTE)  
    references ASSISTE (CODE_ASSISTE) 
    on delete restrict on update restrict;
    A l'ajout de lignes dans la table "enfant", il n'y a pas d'erreur générée si les données ne sont pas trouvées dans les tables "parents" or j'ai besoin de générer une erreur et de sortir de mon traitement ces enregistrements.

    Est-ce normal avec Mysql ? J'ai pourtant ce type d'erreur avec Sybase sauf erreur de ma part, en savez-vous plus ?

    Merci de votre aide !
    NB : Au cas où je n'aurais pas utilisé le bon forum, merci de me le signaler.

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 738
    Points
    11 738
    Par défaut
    Tout dépend du moteur de stockage utilisé... avec InnoDB c'est bon, mais avec MyISAM les FOREIGN KEYS sont ignorées.

    Pour vérifier :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SHOW CREATE TABLE SUIVI_D_UN_DOSSIER ;
    SHOW CREATE TABLE ASSISTE ;
    Les deux tables doivent être en InnoDB.

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 41
    Points : 35
    Points
    35
    Par défaut MyISAM !!!
    Bonjour,

    Merci de votre réponse, vous avez vu juste ! Mes tables utilisent le moteur MyISAM , y-a-til moyen d'en changer ? Comment ? Est-ce compatible avec une utilisation de EasyPHP ?

    Je vais chercher de la documentation sur cette piste, car j'ignorai totalement ces différents moteurs.

    En tout cas, bravo pour la pertinence de la réponse, et merci encore !

  4. #4
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 738
    Points
    11 738
    Par défaut
    Citation Envoyé par remys Voir le message
    Merci de votre réponse, vous avez vu juste ! Mes tables utilisent le moteur MyISAM , y-a-til moyen d'en changer ?
    oui, il suffit de passer cette requête sur chaque table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER TABLE nom_de_la_table ENGINE = InnoDB ;
    Citation Envoyé par remys Voir le message
    Comment ? Est-ce compatible avec une utilisation de EasyPHP ?
    sans problème
    Citation Envoyé par remys Voir le message
    Je vais chercher de la documentation sur cette piste, car j'ignorai totalement ces différents moteurs.
    alors un peu de lecture : http://mysql.developpez.com/faq/?pag...ORMATS_general
    et un article encyclopédique : http://sony-noel.developpez.com/tuto...mysql/moteurs/

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 41
    Points : 35
    Points
    35
    Par défaut Super !
    Pour la doc, le tout est de savoir par où chercher en effet...

    C'est vrai que la doc de Developpez.com est extrêmement bien faite, et je tâcherai de la parcourir davantage avant de créer une nouvelle discussion.

    Les articles cités correspondent tout à fait à mes interrogations sur le sujet.

    Merci, c'est parfait !

  6. #6
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 738
    Points
    11 738
    Par défaut
    Citation Envoyé par remys Voir le message
    Pour la doc, le tout est de savoir par où chercher en effet...
    C'est clair qu'il est difficile de penser à regarder la QR sur les moteurs de stockage quand on ignore leur existence
    Citation Envoyé par remys Voir le message
    C'est vrai que la doc de Developpez.com est extrêmement bien faite, et je tâcherai de la parcourir davantage avant de créer une nouvelle discussion.

    Les articles cités correspondent tout à fait à mes interrogations sur le sujet.

    Merci, c'est parfait !
    you welcome !

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

Discussions similaires

  1. Ignorer les insertions violant les contraintes d'intégrité
    Par pierred69 dans le forum Requêtes
    Réponses: 4
    Dernier message: 13/01/2012, 23h04
  2. Réponses: 2
    Dernier message: 03/11/2009, 16h28
  3. [WD 11] Insertion avec contrainte d'intégrité
    Par leroidje dans le forum WinDev
    Réponses: 9
    Dernier message: 11/12/2007, 14h27
  4. [debutant] Contraintes d'intégrité définies sur un objet
    Par maysa dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 25/05/2004, 14h57
  5. Question sur les contraintes d'intégrités
    Par eGGyyS dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 27/04/2004, 13h51

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