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

PL/SQL Oracle Discussion :

[9i pl/sql] Tester une contrainte de clé étrangère avant son activation [Hors sujet]


Sujet :

PL/SQL Oracle

  1. #21
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Je ne me suis pas soucié de la question d'ordre du DML, car j'ai opté pour la solution de désactivation des contraintes. Pourriez-vous préciser ce à quoi vous faites allusion
    En général, répliquer du DML sans tenir compte de son ordre d'exécution conduit à avoir des données différentes donc ça ne fonctionne pas.

    Exemple:


    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    dev001> drop table t;
     
    Table dropped.
     
    dev001> create table t(x int);
     
    Table created.
     
    dev001> insert into t values (3);
     
    1 row created.
     
    dev001> commit;
     
    Commit complete.
     
    dev001>
    dev001> -- T1
    dev001> update t set x=4 where x=3;
     
    1 row updated.
     
    dev001> commit;
     
    Commit complete.
     
    dev001> -- T2
    dev001> update t set x=5 where x=4;
     
    1 row updated.
     
    dev001> commit;
     
    Commit complete.
     
    dev001> select * from t;
     
             X
    ----------
             5
     
    dev001>
    dev001> truncate table t;
     
    Table truncated.
     
    dev001> insert into t values (3);
     
    1 row created.
     
    dev001> commit;
     
    Commit complete.
     
    dev001>
    dev001>
    dev001> -- T2
    dev001> update t set x=5 where x=4;
     
    0 rows updated.
     
    dev001> commit;
     
    Commit complete.
     
    dev001> -- T1
    dev001> update t set x=4 where x=3;
     
    1 row updated.
     
    dev001> commit
      2  ;
     
    Commit complete.
     
    dev001> select * from t;
     
             X
    ----------
             4

  2. #22
    Membre expérimenté
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2006
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Argentine

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 173
    Points : 1 418
    Points
    1 418
    Par défaut
    Dans ton exemple tu update un champ qui est utilisé par la clause where, ce que je ne fais pas car j'utilise exclusivement la clé primaire comme filtre conditionnel.

  3. #23
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Il peut aussi y avoir des problèmes sans mettre à jour la clé primaire et même en respectant les contraintes (p=table parent, e=table enfant):


    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    dev001> 
    dev001> create table p(x int primary key);
     
    Table created.
     
    dev001> create table e(x int primary key, y references p);
     
    Table created.
     
    dev001> create table bp(x int primary key);
     
    Table created.
     
    dev001> 
    dev001> insert into bp values (0);
     
    1 row created.
     
    dev001> insert into bp values (1);
     
    1 row created.
     
    dev001> insert into bp values (2);
     
    1 row created.
     
    dev001> commit;
     
    Commit complete.
     
    dev001> 
    dev001> create procedure init
      2  as
      3  begin
      4   execute immediate 'truncate table e';
      5   delete p;
      6   insert into p select * from bp;
      7   insert into e values (3,0);
      8   commit;
      9  end;
     10  /
     
    Procedure created.
     
    dev001> show errors
    No errors.
    dev001> 
    dev001> 
    dev001> 
    dev001> exec init;
     
    PL/SQL procedure successfully completed.
     
    dev001> 
    dev001> -- T1
    dev001> update e set y=1 where x=3;
     
    1 row updated.
     
    dev001> commit;
     
    Commit complete.
     
    dev001> -- T2
    dev001> update e set y=2 where x=3;
     
    1 row updated.
     
    dev001> commit;
     
    Commit complete.
     
    dev001> 
    dev001> select * from e;
     
             X          Y                                                           
    ---------- ----------                                                           
             3          2                                                           
     
    dev001> 
    dev001> 
    dev001> exec init;
     
    PL/SQL procedure successfully completed.
     
    dev001> 
    dev001> -- T2
    dev001> update e set y=2 where x=3;
     
    1 row updated.
     
    dev001> commit;
     
    Commit complete.
     
    dev001> -- T1
    dev001> update e set y=1 where x=3;
     
    1 row updated.
     
    dev001> commit
      2  ;
     
    Commit complete.
     
    dev001> select * from e;
     
             X          Y                                                           
    ---------- ----------                                                           
             3          1

  4. #24
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Points : 4 926
    Points
    4 926
    Par défaut
    je ne sais pas si ça aide, mais je tenterais une autre approche :

    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
     
    SQL> create table t1(x number constraint t1_pk primary key);
    Table created.
    SQL> create table t2(y number constraint t2_pk primary key, 
      x number constraint t1_fk references t1 deferrable initially immediate);
    Table created.
    SQL> insert into t1(x) values (1);
    1 row created.
    SQL> insert into t2(y,x) values (1,1);
    1 row created.
    SQL> commit;
    Commit complete.
    SQL> select * from t2;
             Y          X
    ---------- ----------
             1          1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    SQL> set constraint t1_fk deferred;
    Constraint set.
    SQL> insert into t2(y,x) values (2,2);
    1 row created.
    SQL> commit;
    commit
    *
    ERROR at line 1:
    ORA-02091: transaction rolled back
    ORA-02291: integrity constraint (SCOTT.T1_FK) violated - parent key not found
    SQL> select * from t2;
             Y          X
    ---------- ----------
             1          1
    Au lieu de désactiver les contraintes, tu les diffères au moment du commit

  5. #25
    Membre expérimenté
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2006
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Argentine

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 173
    Points : 1 418
    Points
    1 418
    Par défaut
    MAIS
    MAIS

    C'est ça !!!

    Bon, j'essaye ça dès que je peux !

    Merci beaucoup, j'espère que cela marchera avec des contraintes multiples ...

  6. #26
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Avec option de vérifier les données avant le commit.
    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
     
    SQL> SET constraint t1_fk deferred;
     
    Contrainte définie.
     
    SQL> INSERT INTO t2(y,x) VALUES (2,2);
     
    1 ligne créée.
     
    SQL> SET CONSTRAINTS ALL IMMEDIATE;
    SET CONSTRAINTS ALL IMMEDIATE
    *
    ERREUR à la ligne 1 :
    ORA-02291: violation de contrainte (MNI.T1_FK) d'intégrité - touche parent
    introuvable
     
     
    SQL> select * from t2;
     
             Y          X
    ---------- ----------
             1          1
             2          2

  7. #27
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2007
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Bonjour j'ai je croix le même probléme
    Donc voici LE CODE de la table mére PARENT

    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
        /** Ajoute un status dans la base de donnée */
        public void ajouterStatus(String pStatus){
            try{
                //POUR AJOUTER UN STATUS
                for(int i = 0; i < Integer.parseInt(InterfaceDonnee.status.getText()); i++){
                    pStatus = tableDonnee.tabStatus[i];
                    String query = "INSERT INTO STATUS(type_STATUS) VALUES ('" + pStatus + "')";   
                    System.out.println("(INSERT) NB ligne affectés : "+executerUpdate(query));
                }
            }
            catch(Exception e)
            {
               e.printStackTrace();
            }
        }
     
    AFFICHE mes 3 Status ( est une clé primaire dans STATUS) 
     
    maintenant j'ai la table fils ou fille UTILISATEUR 
     
        /** Ajoute un utilisateur dans la base de donnée */
        public void ajouterUtilisateur(String pNom, String pPrenom){
            try{
                //POUR AJOUTER UN UTILISATEUR
     
            //    for(int i=0; i < (Integer.parseInt(InterfaceDonnee.utilisateur.getText())); i++){
                    String nom = donnee.genererNom(pNom);
                    String prenom = donnee.genererPrenom(pPrenom);
                    String pMotDePasse = tableDonnee.tabPrenom[tableDonnee.nbPrenom];
                    String resultatStatus = "";
     
                    String query = "SELECT * FROM STATUS " ;                
                    ResultSet rss = executerRequete(query);
                    for( int i=1; i < (int) (Math.random() * 3); i++){
                        resultatStatus = rss.getString("type_STATUS") ;
                        rss.next();
                    }
     
                    String queryInsert2 = "INSERT INTO UTILISATEUR(type_STATUS) VALUES ('" + resultatStatus + "')";   
                    System.out.println("(INSERT) NB ligne affectés : "+ executerUpdate(queryInsert2));
     
                    String queryInsert = "INSERT INTO UTILISATEUR VALUES ('" + nom + "', '" + prenom + "', '" + pMotDePasse + "')";   
                    System.out.println("(INSERT) NB ligne affectés : "+ executerUpdate(queryInsert));
     
            }
            catch(Exception e)
            {
               e.printStackTrace();
            }
        }
    AFFICHE : Before start of result set

    type_STATUS est une clé étrangére dans UTILISATEUR

    j'ai débugger et il affiche une exception quand il arrive a la ligne
    resultatStatus = rss.getString("type_STATUS") ;

    je vous remercie de vos réponse. a+

  8. #28
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
                    String query = "SELECT * FROM STATUS " ;                
                    ResultSet rss = executerRequete(query);
                    for( int i=1; i < (int) (Math.random() * 3); i++){
                        resultatStatus = rss.getString("type_STATUS") ;
                        rss.next();
                    }
    Je pense que si tu arrive à nous expliquer ce que tu veut faire ici tu comprendras ton problème
    Remarque, ce code java montre pas mal des problèmes

  9. #29
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2007
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
                    String query = "SELECT * FROM STATUS " ;                
                    ResultSet rss = executerRequete(query);
                    for( int i=1; i < (int) (Math.random() * 3); i++){
                        resultatStatus = rss.getString("type_STATUS") ;
                        rss.next();
                    }
    Je pense que si tu arrive à nous expliquer ce que tu veut faire ici tu comprendras ton problème
    Remarque, ce code java montre pas mal des problèmes
    Salut mnitu
    ce que je veux faire, j'ai 2 tables un parent et un enfant
    dans l'enfant y'a la clé étrangére du parent (type_STATUS FROM STATUS)

    je souhaiterai INSERT les type_STATUS de STATUS dans l'enfant (UTILISATEUR)
    Mais quand je String query = "SELECT * FROM STATUS " ;
    le compilateur bugg a cette ligne
    ResultSet rss = executerRequete(query);
    Et désoler pour mon code java
    JE NE SUIS PAS UN EXPERT
    j'éspère que quelqu'un aura la gentillesse de m'aider. voilà merci d'avance
    à bientôt.

  10. #30
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Bonjour sultan173,

    Peut tu ouvrir une autre discussion en reprenant ton exemple parce que ton problème n'est pas vraiment lié à celui ci ? Peut être ensuite un des rédacteurs pourrait l'éditer.

Discussions similaires

  1. [11gR2] Sur quelle table porte une contrainte de clé étrangère ?
    Par CinePhil dans le forum SQL
    Réponses: 2
    Dernier message: 27/02/2015, 11h09
  2. Ajouter une contrainte de clé étrangère
    Par cedrix57 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 29/12/2009, 03h35
  3. Réponses: 29
    Dernier message: 25/11/2007, 16h08
  4. Réponses: 5
    Dernier message: 28/04/2006, 11h55
  5. [SQL] desactiver une contrainte de clé primaire puis l'a reactive
    Par SanTa62 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 12/01/2006, 08h50

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