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

Outils Firebird Discussion :

Création clé étrangère impossible


Sujet :

Outils Firebird

  1. #1
    Membre chevronné Avatar de Mister Nono
    Homme Profil pro
    Ingénieur Mathématiques et Informatique
    Inscrit en
    Septembre 2002
    Messages
    2 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur Mathématiques et Informatique
    Secteur : Santé

    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 232
    Points : 1 897
    Points
    1 897
    Par défaut Création clé étrangère impossible
    Bonjour,

    Voici le script suivant :

    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
     
    SET NAMES NONE;
     
    CONNECT 'path de la base';
     
     
    SET SQL DIALECT 3;
     
    SET NAMES NONE;
     
     
    drop table utilisateur;
    drop table privilege;
     
     
    commit;
     
    /******************************************************************************/
    /***                                 Tables                                 ***/
    /******************************************************************************/
     
     
     
    CREATE TABLE PRIVILEGE (
        ID_PR   INTEGER NOT NULL,
        NOM_PR  VARCHAR(30)
    );
     
     
     
     
     
     
     
     
    /******************************************************************************/
    /***                              Primary Keys                              ***/
    /******************************************************************************/
     
    ALTER TABLE PRIVILEGE ADD PRIMARY KEY (ID_PR);
     
     
     
    /******************************************************************************/
    /***                                 Tables                                 ***/
    /******************************************************************************/
     
     
     
    CREATE TABLE UTILISATEUR (
        MATRICULE_U    VARCHAR(30) NOT NULL,
        LOGIN_U        VARCHAR(30) NOT NULL,
        PASSWORD_U     VARCHAR(30) NOT NULL,
        NOM_U          VARCHAR(30),
        PRENOM_U       VARCHAR(30),
        SERVICE_U      VARCHAR(30),
        COMMENTAIRE_U  VARCHAR(30),
        TELEPHONE      VARCHAR(30),
        FAX            VARCHAR(30),
        EMAIL          VARCHAR(30),
        ID_PR          INTEGER NOT NULL
    );
     
     
     
     
    /******************************************************************************/
    /***                              Primary Keys                              ***/
    /******************************************************************************/
     
    ALTER TABLE UTILISATEUR ADD PRIMARY KEY (MATRICULE_U);
     
     
     
     
     
    /******************************************************************************/
    /***                              Foreign Keys                              ***/
    /******************************************************************************/
     
    ALTER TABLE UTILISATEUR ADD CONSTRAINT FK_UTILISATEUR_1 FOREIGN KEY (ID_PR) REFERENCES PRIVILEGE (ID_PR);
     
     
     
    commit;
    ... il crée les table mais ne veut pas renseigner la contrainte nommée FK_UTILISATEUR_1 à cause de l'erreur suivante (dans l'éditeur IBExpert) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    This operation is not defined for system tables. Unsuccessfull metadata update.  Object PRIVILEGE is in use.
    Pourquoi ce message ?

    Merci.
    La connaissance ne sert que si elle est partagée.
    http://ms2i.net

  2. #2
    Membre expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Points : 3 712
    Points
    3 712
    Par défaut
    j'image que tu lances ce script dans un GUI, hors ce GUI doit accéder d'une manière ou d'une autre à ta table, et il se trouve qu'avec Firebird <2, il faut un accès exclusif à la table pour créer ta clé étrangère
    donc soit passe par isql soit choisit un GUI plus "intelligent", qui ne monopolise pas bêtement les tables, où alors passe à Firebird 2
    Philippe Makowski
    IBPhoenix - Firebird
    Membre de l'April

  3. #3
    Membre du Club
    Inscrit en
    Juillet 2002
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 84
    Points : 67
    Points
    67
    Par défaut Même problème...
    Bonjour,

    J'ai essayé la commande ALTER TABLE pour déclarer mes clés secondaires avec IBEasy+ et ISQL et dans les 2 cas j'ai le même message :
    Statement failed, SQLCODE = -607
    unsucessful metadata update
    -object nomdematable is in use
    cgone.

  4. #4
    Membre expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Points : 3 712
    Points
    3 712
    Par défaut
    ben je t'assure qu'avec isql, ça passe
    create table
    commit
    alter table
    Philippe Makowski
    IBPhoenix - Firebird
    Membre de l'April

  5. #5
    Membre chevronné Avatar de Mister Nono
    Homme Profil pro
    Ingénieur Mathématiques et Informatique
    Inscrit en
    Septembre 2002
    Messages
    2 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur Mathématiques et Informatique
    Secteur : Santé

    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 232
    Points : 1 897
    Points
    1 897
    Par défaut
    Et avec IBEASY+ aussi.
    La connaissance ne sert que si elle est partagée.
    http://ms2i.net

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

Discussions similaires

  1. création clé étrangère
    Par bruce207 dans le forum Modélisation
    Réponses: 4
    Dernier message: 02/01/2008, 15h53
  2. [phpMyAdmin] Problème création Clé étrangère (FK)
    Par irnbru dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 16/05/2007, 19h34
  3. Création d'executable impossible
    Par ForceTranquille dans le forum Langage
    Réponses: 7
    Dernier message: 24/04/2007, 14h07
  4. Problème création clés étrangères
    Par sat478 dans le forum Débuter
    Réponses: 1
    Dernier message: 01/05/2006, 15h53
  5. création de clé étrangère impossible
    Par Kozher dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 05/08/2005, 10h38

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