Précédent   Forum des professionnels en informatique > Bases de données > Autres SGBD > InterBase
InterBase Forum d'entraide sur le SGBD InterBase de Codegear. Avant de poster -> F.A.Q Interbase, Tutoriels
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 30/11/2007, 12h21   #1
Membre à l'essai
 
Étudiant
Inscription : juillet 2006
Messages : 57
Détails du profil
Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : juillet 2006
Messages : 57
Points : 22
Points : 22
Par défaut [IB6]Probleme de Primary key

bonjour ;
j'ai crée une table avec interbase 6.0 et voila le code:

Code :
1
2
3
4
5
6
7
8
9
10
11
 
CREATE TABLE "FICHEPATIENT" 
(
  "NINSCRIPTION"	VARCHAR(10) NOT NULL,
  "NOM"	VARCHAR(50) NOT NULL,
  "PRENOM"	VARCHAR(50) NOT NULL,
  "JOUR"	        INTEGER,
  "MOIS"	         INTEGER,
  "ANNEE" 	INTEGER,
  CONSTRAINT "NPP" PRIMARY KEY ("NINSCRIPTION", "NOM", "PRENOM")
);
seleument chaque fois j'essaye de modifier en inserant les champs jour,mois,et annee dans la primary key,il m'affiche une erreur.alors je me demande si l'erreur se produit car ces champs sont des nombres!
bonbino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/11/2007, 12h33   #2
Modérateur
 
Avatar de Cl@udius
 
Homme Claude Renouleaud
Développeur informatique
Inscription : février 2006
Messages : 4 758
Détails du profil
Informations personnelles :
Nom : Homme Claude Renouleaud
Âge : 49
Localisation : France, Hautes Pyrénées (Midi Pyrénées)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : février 2006
Messages : 4 758
Points : 6 779
Points : 6 779
Salut

Citation:
Envoyé par bonbino Voir le message
il m'affiche une erreur
Quelle est cette erreur ? Elle se produit lors d'une insertion, d'une modification ?

@+
__________________
A la question technique que par MP/MV tu formuleras, la réponse aux oubliettes finira.
Cl@udius est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/11/2007, 16h51   #3
Membre à l'essai
 
Étudiant
Inscription : juillet 2006
Messages : 57
Détails du profil
Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : juillet 2006
Messages : 57
Points : 22
Points : 22
j'ai ce probleme lors d'une modification,alors je commence par eliminer l'ancienne primary key avec :

Code :
1
2
3
 
ALTER TABLE FICHEPATIENT
DROP CONSTRAINT NP
ensuite si je veux inserer la nouvelle primary key avec:

Code :
1
2
3
 
ALTER TABLE FICHEPATIENT
ADD CONSTRAINT NP PRIMARY KEY (NINSCRIPTION, NOM, PRENOM ,ANNEE,MOIS,JOUR)
j'aurrai le message d'erreur suivant:

Citation:
Unsuccessful metadata update
Unknown columns in index RDB$PRIMARY41
bonbino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/11/2007, 17h40   #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
quelque fois tu écris NP, d'autres fois NPP


Code :
1
2
3
4
5
ALTER TABLE FICHEPATIENT
DROP CONSTRAINT NPP;
COMMIT;
ALTER TABLE FICHEPATIENT
ADD CONSTRAINT NPP PRIMARY KEY (NINSCRIPTION, NOM, PRENOM,ANNEE,MOIS,JOUR);
et c'est quoi cette manie de mettre les noms de tables et de champs entre guillemets et ainsi les rendre sensible à la casse ?
__________________
Philippe Makowski
IBPhoenix - Firebird
Membre de l'April
makowski est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/11/2007, 19h03   #5
Membre à l'essai
 
Étudiant
Inscription : juillet 2006
Messages : 57
Détails du profil
Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : juillet 2006
Messages : 57
Points : 22
Points : 22
j'ai toujours le meme message!!!
le probleme c'est pas d'effacer et d'ajouter la primary key au meme temps,le probleme est que l'interbase n'accepte pas les 3 derniers champs dans la primary key.
et pour la maniere d'ecriture des champs(entre deux tirés),j'ai copier directeument la structure du metadata.
merci pour l'aide
bonbino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/12/2007, 11h17   #6
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
interbase , je passe
__________________
Philippe Makowski
IBPhoenix - Firebird
Membre de l'April
makowski est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/12/2007, 08h06   #7
Modérateur
 
Avatar de SergioMaster
 
Serge Girard
Développeur informatique
Inscription : janvier 2007
Messages : 3 630
Détails du profil
Informations personnelles :
Nom : Serge Girard
Âge : 55
Localisation : France

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

Informations forums :
Inscription : janvier 2007
Messages : 3 630
Points : 4 532
Points : 4 532
Je crois que cela vient du fait que tous les champs d'un clé primaire doivent être déclarés non null

je ne sais pas si c'est encore valable pour les nouvelles versions , mais je suis resté sur ce principe (qui ne fait pas de mal)
__________________
La seule chose absolue dans un monde comme le nôtre, c'est l'humour. » Albert Einstein
J'entends et j'oublie. Je vois et je me souviens. Je fais et je comprends . Confucius
SergioMaster est actuellement 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 07h29.


 
 
 
 
Partenaires

Hébergement Web