Précédent   Forum des professionnels en informatique > Bases de données > Firebird > Outils
Outils Forum d'entraide sur les outils tiers pour Firebird
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 09/10/2006, 15h37   #1
Membre Expert
 
Inscription : septembre 2002
Messages : 1 638
Détails du profil
Informations personnelles :
Âge : 48
Localisation : France, Hérault (Languedoc Roussillon)

Informations forums :
Inscription : septembre 2002
Messages : 1 638
Points : 1 000
Points : 1 000
Par défaut Création clé étrangère impossible

Bonjour,

Voici le script suivant :

Code :
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 :
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
Mister Nono est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/10/2006, 16h15   #2
Expert Confirmé

 
Homme Philippe Makowski
Consultant spécialité Firebird
Inscription : mai 2002
Messages : 2 215
Détails du profil
Informations personnelles :
Nom : Homme Philippe Makowski
Âge : 49
Localisation : France

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

Informations forums :
Inscription : mai 2002
Messages : 2 215
Points : 3 318
Points : 3 318
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
makowski est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 10/10/2006, 05h41   #3
Nouveau Membre du Club
 
Inscription : juillet 2002
Messages : 84
Détails du profil
Informations forums :
Inscription : juillet 2002
Messages : 84
Points : 35
Points : 35
Envoyer un message via MSN à cgone
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 :
Citation:
Statement failed, SQLCODE = -607
unsucessful metadata update
-object nomdematable is in use
cgone.
cgone est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 10/10/2006, 14h31   #4
Expert Confirmé

 
Homme Philippe Makowski
Consultant spécialité Firebird
Inscription : mai 2002
Messages : 2 215
Détails du profil
Informations personnelles :
Nom : Homme Philippe Makowski
Âge : 49
Localisation : France

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

Informations forums :
Inscription : mai 2002
Messages : 2 215
Points : 3 318
Points : 3 318
ben je t'assure qu'avec isql, ça passe
create table
commit
alter table
__________________
Philippe Makowski
IBPhoenix - Firebird
Membre de l'April
makowski est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 10/10/2006, 15h16   #5
Membre Expert
 
Inscription : septembre 2002
Messages : 1 638
Détails du profil
Informations personnelles :
Âge : 48
Localisation : France, Hérault (Languedoc Roussillon)

Informations forums :
Inscription : septembre 2002
Messages : 1 638
Points : 1 000
Points : 1 000
Et avec IBEASY+ aussi.
__________________
La connaissance ne sert que si elle est partagée.
http://ms2i.net
Mister Nono est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 17h11.


 
 
 
 
Partenaires

Hébergement Web