Précédent   Forum des professionnels en informatique > Bases de données > Langage SQL
Langage SQL Forum d'entraide sur le langage SQL et sur les questions liées à la conception de schéma (DDL). Cours SQL
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 05/03/2011, 20h39   #1
Invité de passage
 
Inscription : mars 2011
Messages : 12
Détails du profil
Informations personnelles :
Localisation : France

Informations forums :
Inscription : mars 2011
Messages : 12
Points : 1
Points : 1
Par défaut Contrainte d'unicité sur 6 colonnes

Bonjour,

Pour éviter des doublons, puis-je utiliser une contrainte d'unicité sur 6 colonnes sans que cela ne pose un problème ?

Merci.
sarabaïte est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2011, 21h27   #2
Membre Expert
 
Inscription : août 2008
Messages : 1 271
Détails du profil
Informations forums :
Inscription : août 2008
Messages : 1 271
Points : 1 929
Points : 1 929
6 n'est pas un problème, mais concrètement une contrante d'unicité est généralement associée à un index unique cependant contrainte d'uncité est différent d'index unique.

Comme il existe des restrictions sur la création des index, si les 6 colonnes sont de type varchar(255) alors il est probable que ça ne fonctionne pas, la limite dépendant probablement du SGBD utilisé.

Quel est le SGBD, quel est le typage des 6 colonnes en questions, qu'as tu observé lors de la création de la contrainte ?
skuatamad est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2011, 22h14   #3
Invité de passage
 
Inscription : mars 2011
Messages : 12
Détails du profil
Informations personnelles :
Localisation : France

Informations forums :
Inscription : mars 2011
Messages : 12
Points : 1
Points : 1
Par défaut suite...

Bonsoir,

j'utilise Mysql et mes colonnes sont de type :
int, date, tinyint, int, char, int

pour l'instant, je m'interroge seulement pour savoir si ça se pratique ou non...
sarabaïte est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2011, 22h19   #4
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 544
Points : 9 544
De manière générale, on pose toutes les contraintes qui sont fonctionnellement nécessaires.

Dans ce cas particulier, MySQL ne distingue pas les notions de clé et d'index, donc effectivement ça se traduit par un index UNIQUE sur ces six colonnes.
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2011, 22h30   #5
Invité de passage
 
Inscription : mars 2011
Messages : 12
Détails du profil
Informations personnelles :
Localisation : France

Informations forums :
Inscription : mars 2011
Messages : 12
Points : 1
Points : 1
Par défaut pour conclure

Merci.

Donc, je peux faire :

UNIQUE idx_six_col (col1, col2, col3, col4, col5, col6) ?
sarabaïte est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2011, 22h41   #6
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 544
Points : 9 544
Tu as mon feu vert
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/03/2011, 22h43   #7
Invité de passage
 
Inscription : mars 2011
Messages : 12
Détails du profil
Informations personnelles :
Localisation : France

Informations forums :
Inscription : mars 2011
Messages : 12
Points : 1
Points : 1
Par défaut Ok

Je vais pouvoir dormir en paix.
sarabaïte 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 17h32.


 
 
 
 
Partenaires

Hébergement Web