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

PL/SQL Oracle Discussion :

Ajout d'une colonne avec une valeur par defaut


Sujet :

PL/SQL Oracle

  1. #1
    Nouveau membre du Club
    Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2003
    Messages
    33
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Janvier 2003
    Messages : 33
    Points : 28
    Points
    28
    Par défaut Ajout d'une colonne avec une valeur par defaut
    Bonjour, je dois ajouter une colonne dans une table mais j'aimerais indiquer que ce champs ne peu pas être null et lui donner une valeur par defaut.

    Pour l'ajout je fais la commande suivante :

    ALTER TABLE COMNC
    ADD IND_ENV_COURL char(1 byte);

    Je dois lui mettre 'O' par defaut et rendre ce champs obligatoire (NULL = N)

    Puis-je le faire dans une seule commande lors de l'ajout de la colonne ou je dois crer la colonne et faire les ajour par après !!

    Un gros merci !!
    Rumeurs

  2. #2
    Membre confirmé Avatar de NGasparotto
    Inscrit en
    Janvier 2007
    Messages
    421
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 421
    Points : 603
    Points
    603
    Par défaut
    Qu'est-ce qui empeche d'essayer ?
    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
    SQL> create table COMNC (col1 number);
     
    Table created.
     
    Elapsed: 00:00:00.00
    SQL> insert into COMNC values (1);
     
    1 row created.
     
    Elapsed: 00:00:00.00
    SQL> select * from COMNC;
     
          COL1
    ----------
             1
     
    Elapsed: 00:00:00.00
    SQL> alter table COMNC add IND_ENV_COURL char(1 byte) default 'O' not null;
     
    Table altered.
     
    Elapsed: 00:00:00.00
    SQL> select * from COMNC;
     
          COL1 I
    ---------- -
             1 O
     
    Elapsed: 00:00:00.00
    SQL>
    Nicolas.

  3. #3
    Nouveau membre du Club
    Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2003
    Messages
    33
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Janvier 2003
    Messages : 33
    Points : 28
    Points
    28
    Par défaut
    Merci Nicolas...assez logique

    Je pensais l'avoir essayer mais y faut croire que non !!

    Un gros merci !!
    Rumeurs

  4. #4
    Membre confirmé Avatar de NGasparotto
    Inscrit en
    Janvier 2007
    Messages
    421
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 421
    Points : 603
    Points
    603
    Par défaut
    Attention toutefois, si la colonne ajoutee est DATE avec un DEFAULT a SYSDATE, y a un bug :
    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
    Personal Oracle Database 11g Release 11.1.0.7.0 - Production
    With the Partitioning, OLAP, Data Mining and Real Application Testing options
     
    SQL> create table mytable(id number);
     
    Table created.
     
    SQL> insert into mytable values(1);
     
    1 row created.
     
    SQL> alter table mytable add mydate date default sysdate not null;
     
    Table altered.
     
    SQL> insert into mytable(id) values(2);
     
    1 row created.
     
    SQL> select * from mytable;
     
            ID MYDATE
    ---------- ---------
             1 00-DECEMB
             2 13-JUL-09
     
    SQL>
    Dans ce cas, il faut faire en trois etapes, d'abord ajouter la colonne, puis update avec sysdate, enfin mettre DEFAULT, ca fonctionnera correctement pour les nouvelles lignes inserees.

    Nicolas.

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

Discussions similaires

  1. [WD14] Alimentation d'une colonne d'une tableau avec une autre colonne
    Par Deep Lowee dans le forum WinDev
    Réponses: 2
    Dernier message: 23/01/2013, 17h44
  2. Réponses: 7
    Dernier message: 25/03/2011, 10h52
  3. [XL-2002] Macro de comparaison d'une cellule d'une feuille avec une cellule d'une autre feuille.
    Par steelydan dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/09/2010, 12h59
  4. [AC-2003] Renommer une colonne d'une requête avec la valeur d'un champ
    Par constalp dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 11/08/2010, 12h03
  5. Réponses: 4
    Dernier message: 15/10/2009, 13h33

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