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

SQL Oracle Discussion :

Contrainte sur le contenu d'une colonne [11g]


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2015
    Messages
    102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2015
    Messages : 102
    Par défaut Contrainte sur le contenu d'une colonne
    Bonsoir voici le model relationnel de ma table Compte :Compte ( num_cpt, nature_cpt, solde_cpt, avoir_cpt, #code_ag, #mat_emp)
    mon souci est au niveau de la contrainte vis a vis de la colone nature_cpt ou on memande que :La nature du compte peut prendre uniquement les valeurs : compte courant, compte epargne, compte dépôt à terme
    alors voici ce que j ai pu implementé à ce niveau
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    CREATE TABLE  Compte (
      num_cpt VARCHAR(10), 
     nature_cpt VARCHAR(25), 
     solde_cpt NUMBER(10), 
     avoir_cpt NUMBER(10), 
     code_ag VARCHAR (10),
     mat_emp VARCHAR (10),
    CONSTRAINT pk_Compte PRIMARY KEY (num_cpt)
    CONSTRAINT C1_Compte CHECK  (nature_cpt in ('compte courant','compte epargne','compte depot'));
    )
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    CREATE TABLE  Compte (
      num_cpt VARCHAR(10), 
     nature_cpt VARCHAR(25), 
     solde_cpt NUMBER(10), 
     avoir_cpt NUMBER(10), 
     code_ag VARCHAR (10),
     mat_emp VARCHAR (10),
    CONSTRAINT pk_Compte PRIMARY KEY (num_cpt)
    CONSTRAINT C1_Compte CHECK (nature_cpt='compte courant'or nature_cpt='compte epargne'or nature_cpt='compte dépôt à terme')
    je suis nouveau et j ai besoin un peu éclaircissement §
    je voudrais me rassurer si mes codes sont corrects
    Merci...

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    La bonne solution, c'est de créer une table de référence avec tes libellés de nature de compte associés à un identifiant et d'enregistrer dans la colonne nature_cpt non pas le libellé mais l'identifiant, avec une contrainte d’intégrité référentielle vers ta table de référence.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2015
    Messages
    102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2015
    Messages : 102
    Par défaut
    je suis un peu perdu je parviens pas à cerner votre solution

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    Comme ça, c'est plus clair ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    CREATE TABLE    tr_nature_cpt
        (   id_nature_cpt   NUMBER      NOT NULL
        ,   nature_cpt      VARCHAR(25) NOT NULL
        ,   CONSTRAINT
                pk_nature_cpt
            PRIMARY KEY
                (   id_nature_cpt
                )
        ,   CONSTRAINT
                uk_nature_cpt
            UNIQUE
                (   nature_cpt
                )
        )
    ;
    INSERT INTO tr_nature_cpt
        (   id_nature_cpt
        ,   nature_cpt
        )
    SELECT  1,  'compte courant'    FROM DUAL UNION
    SELECT  2,  'compte epargne'    FROM DUAL UNION
    SELECT  3,  'compte depot'      FROM DUAL
    ;
     
    CREATE TABLE  Compte 
        (   num_cpt     VARCHAR(10)
        ,   nature_cpt  NUMBER 
        ,   solde_cpt   NUMBER(10) 
        ,   avoir_cpt   NUMBER(10) 
        ,   code_ag     VARCHAR(10)                                     
        ,   mat_emp     VARCHAR(10)
        ,   CONSTRAINT  pk_Compte 
            PRIMARY KEY 
                (   num_cpt
                )
        ,   CONSTRAINT  fk_compte_nature_cpt
            FOREIGN KEY
                (   id_nature_cpt
                )
            REFERENCES  tr_nature_cpt
     
                (   id_nature_cpt
                )
        )
    ;
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  5. #5
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2015
    Messages
    102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2015
    Messages : 102
    Par défaut
    Merci

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

Discussions similaires

  1. [XL-2007] Extraction de contenu d'une colonne sur plusieurs colonnes
    Par Stanir dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 04/12/2009, 10h36
  2. Récuperer le contenu d'une colonne sur une ligne
    Par Empty_body dans le forum Langage SQL
    Réponses: 2
    Dernier message: 28/08/2009, 12h30
  3. Réponses: 4
    Dernier message: 27/11/2007, 15h32
  4. Réponses: 4
    Dernier message: 30/06/2006, 15h26
  5. Index sur le contenu d'une colonne XMLTYPE
    Par haugoyard dans le forum Oracle
    Réponses: 7
    Dernier message: 11/04/2005, 11h10

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