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 :

Modifier une colonne en enlevant le caractère virtuel [11gR2]


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Septembre 2004
    Messages
    378
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 378
    Par défaut Modifier une colonne en enlevant le caractère virtuel
    Bonjour,

    Je cherche à enlever le caractère virtuel d'une colonne car la règle de gestion ayant changé.
    Je cherche donc à enlever le "DATA_DEFAULT" mais je n'y arrive pas.
    Il vaut mieux que je crée une colonne "normale" et que je supprime l'ancienne "virtuelle" ?

    Merci de votre aide.

  2. #2
    Membre actif
    Homme Profil pro
    développeur Oracle
    Inscrit en
    Février 2014
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Roumanie

    Informations professionnelles :
    Activité : développeur Oracle
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Février 2014
    Messages : 27
    Par défaut
    Je crois que tu dois ajouter une nouvelle colonne 'non-virtual', copier la teneur de la colonne virtuelle dans cette nouvelle colonne et enfin le supprime la vieille colonne.

    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
    CREATE TABLE employees (ID NUMBER, NAME VARCHAR2(100), 
    salary NUMBER,
    fee NUMBER GENERATED ALWAYS AS (salary*0.03) VIRTUAL
    )
     
    INSERT INTO employees (ID, NAME, salary) VALUES (1, 'George', 1000);
    INSERT INTO employees (ID, NAME, salary) VALUES (2, 'Tom', 1500);
    INSERT INTO employees (ID, NAME, salary) VALUES (3, 'Michael', 1200);
    INSERT INTO employees (ID, NAME, salary) VALUES (4, 'Steven', 1100);
     
    SELECT * FROM employees
     
    ALTER TABLE employees ADD new_fee NUMBER
     
    UPDATE employees SET new_fee = fee
     
    ALTER TABLE employees DROP COLUMN fee
     
    SELECT * FROM employees

  3. #3
    Membre éclairé
    Inscrit en
    Septembre 2004
    Messages
    378
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 378
    Par défaut
    Oui je pense que c'est une bonne solution
    Merci

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 05/06/2008, 13h53
  2. modifier une colonne existante en colonne calculé
    Par m-mas dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 05/07/2007, 12h43
  3. [SQLServer2000] Modifier une colonne
    Par Pierrick dans le forum Langage SQL
    Réponses: 1
    Dernier message: 03/03/2007, 19h10
  4. Modifier une colonne qui possède une contrainte DEFAUT
    Par David.V dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 23/01/2007, 11h35

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