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

Développement SQL Server Discussion :

check dans sql manager studio 2008


Sujet :

Développement SQL Server

  1. #1
    Membre actif Avatar de chris81
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 626
    Points : 298
    Points
    298
    Par défaut check dans sql manager studio 2008
    Bonjour,
    comment puis je faire pour créer un champ par exemple 'Structure' nvarchar(50) et je ne souhaite que l'on puisss y insérer que "SARL" ou "EURL" ou "SAS"

    en fait comment faire un check dans sql manager studio 2008 ?

    merci

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Tout d'abord, pourquoi utiliser le type NVARCHAR ? Cela consomme 2 octets pour tout caractère puisque vous stockez les chaînes en unicode.
    Si vous utilisez VARCHAR, vous n'utiliseriez qu'un seul octet par caractère.
    N'utilisez les types NCHAR et NVARCHAR que lorsque vous avez besoin de stocker des caractères non-latins (chinois, japonais, coréen, thaï, arabe, hébreux, arménien ...)

    Pour votre contrainte de domaine, vous pouvez exécuter, dans SQL Server Management Studio :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ALTER TABLE maTable
    ADD Structure VARCHAR(5) NOT NULL CONSTRAINT CHK_maTable_Structure CHECK (Structure NOT IN ('SARL', 'EURL', 'SAS'))
    Mais vous pouvez allez plus loin en écrivant une fonction pour cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    CREATE FUNCTION Fn_Check_Structure_Nom
    	@nomStructure VARCHAR(5)
    RETURNS BIT
    WITH SCHEMABINDING
    AS
    BEGIN
    	RETURN CASE
    				WHEN @nomStructure IN ('SARL', 'EURL', 'SAS') THEN CAST(0 AS BIT)
    				ELSE 1
    			END
    END
    Et ensuite, pour votre table :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ALTER TABLE maTable
    ADD Structure VARCHAR(5) NOT NULL CONSTRAINT CHK_maTable_Structure CHECK(dbo.Fn_Check_Structure_Nom(Structure) = 1)
    Ainsi si vous devez retirer ou ajouter une valeur pour votre contrôle, il vous suffit de mettre à jour la fonction, pas la contrainte

    Vous pouvez aussi utiliser cette fonction pour interroger une table de valeurs interdites pour votre contrainte ...

    @++

  3. #3
    Membre actif Avatar de chris81
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 626
    Points : 298
    Points
    298
    Par défaut
    OUAH!!! merci pour cette réponse ultra compléte et surtout merci d'avor mis un exemple

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 02/03/2015, 23h26
  2. Réponses: 1
    Dernier message: 23/10/2013, 16h04
  3. SQL Management Studio 2008 R2
    Par malouch dans le forum Outils
    Réponses: 2
    Dernier message: 27/04/2011, 16h38
  4. installation sql management studio 2008
    Par DOJO_Samir dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 28/11/2010, 12h15
  5. Probleme dans installation de Sql Server Management Studio 2008
    Par Oussama1 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 21/02/2010, 18h11

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