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

Administration MySQL Discussion :

Index unique multi-colonnes et champ null


Sujet :

Administration MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Femme Profil pro
    Responsable Industrialisation
    Inscrit en
    Avril 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable Industrialisation
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2017
    Messages : 2
    Par défaut Index unique multi-colonnes et champ null
    Bonjour,

    J'ai un table contenant trois colonnes:
    - FROM
    - GAME
    - START

    J'aimerais assurer l'unicité du binôme FROM/GAME lorsque la colonne START est vide.
    Sont acceptés:
    FROM | GAME | START
    A | 1 | 10
    A | 1 | 20

    Sont refusés:
    FROM | GAME | START
    A | 1 | NULL
    A | 1 | NULL

    Sachant que la colonne START sera unique (DATETIME), j'ai essayé en créant un index unique que les trois colonnes mais ça ne fonctionne pas si un champ est vide.

    Quelle est la bonne méthode ?
    Merci.

    Edit : J'ai contourné la problème en n'autorisant plus une valeur NULL pour START.

  2. #2
    Membre prolifique Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 883
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 883
    Par défaut
    Salut coeur2lyon69.

    Si vous ne désirez pas le "NULL", il suffit de le préciser dans la déclarative de vos colonnes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    `from`   varchar(255)      not null,
    `game`   integer unsigned  not null,
    `start`  datetime          not null,
    Pour la déclarative de l'index unique, il suffit de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    unique index `idx` (`from`,`game`,`start`)
    Ainsi le triplé sera unique.

    Citation Envoyé par coeur2lyon69
    Sachant que la colonne START sera unique (DATETIME)
    Il y a un léger problème avec votre colonne "start".
    Si vous choisissez le type "datetime", et si vous précisez qu'elle ne doit pas être NULL, vous devez alors préciser une valeur particulière.
    Le mieux dans ce cas est de mettre "1970-01-01 00:00:00" qui est la plus petite valeur autorisée.
    Et pour ne pas avoir à la gérer de cette façon, il suffit de modifier la déclarative :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    `start`  datetime      not null  default '1970-01-01 00:00:00',
    A chaque vous que vous mettrez "DEFAULT" comme valeur de cette colonne, c'est la valeur '1970-01-01 00:00:00' qui sera mis !

    [quote="coeur2lyon69"]J'aimerais assurer l'unicité du binôme FROM/GAME lorsque la colonne START est vide.[/code]
    Peu importe la valeur de la colonne start, le triplé sera unique.

    @+

  3. #3
    Nouveau candidat au Club
    Femme Profil pro
    Responsable Industrialisation
    Inscrit en
    Avril 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable Industrialisation
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2017
    Messages : 2
    Par défaut
    Bonjour,
    Initialement, je souhaitais conserver la possibilité d'avoir une valeur NULL pour 'start', mais apparemment il n'est pas possible d'assurer l'unicité avec MySQL.

    La solution proposée marche parfaitement.
    Merci !

  4. #4
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 228
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 228
    Billets dans le blog
    25
    Par défaut
    que vous donne un
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  5. #5
    Membre prolifique Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 883
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 883
    Par défaut
    Salut Fadace.

    Quel est le rapport avec le problème du NULL dans un index unique ?

    @+

Discussions similaires

  1. Réponses: 10
    Dernier message: 04/03/2013, 19h15
  2. [2.x] Création Index Unique multi-colonne
    Par arcandre dans le forum Symfony
    Réponses: 2
    Dernier message: 22/04/2012, 18h05
  3. Réponses: 3
    Dernier message: 02/05/2006, 21h36
  4. Réponses: 7
    Dernier message: 27/04/2006, 10h21
  5. Sql Server Express - Probleme index unique et valeurs null
    Par Fayoul dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 17/02/2006, 17h22

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