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 Firebird Discussion :

Restructuration d'un BDD


Sujet :

SQL Firebird

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Avatar de Andry
    Profil pro
    Informaticien
    Inscrit en
    Juillet 2002
    Messages
    1 164
    Détails du profil
    Informations personnelles :
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 164
    Par défaut Restructuration d'un BDD
    Salut à tous,
    J'ai une BDD sous interbase 6 Open Edition.
    Est ce possible de changer la valeur par defaut d'un champs de type Date.
    J'aimerais rajoutter que la valeur par defaut est Null.

    Merci

  2. #2
    Rédacteur
    Avatar de WOLO Laurent
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Mars 2003
    Messages
    2 741
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Congo-Brazzaville

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 2 741
    Par défaut
    Essaie ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER COLUMN MaColonne datetime null

    Découvrez la FAQ de MS SQL Server.
    La chance accorde ses faveurs aux esprits avertis !

  3. #3
    Membre Expert
    Avatar de Barbibulle
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    2 052
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 2 052
    Par défaut
    Hélas on ne peux pas modifier en une seule commande la valeur par défaut d'une colonne.

    Si ta colonne date n'est pas liée à d'autres objets (index, clé étrangères etc) alors le plus simple est de créer une colonne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ALTER TABLE "MaTable" ADD TEMP_DATE
     DATE DEFAULT  NULL
    Ensuite copie des données de la colonne ColonneDate dans la Colonne TEMP_DATE
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    UPDATE "MaTable" set TEMP_DATE="ColonneDate";
    Effacement de l'ancienne colonne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alter table "MaTable" drop "ColonneDate"
    Re mettre la colonne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ALTER TABLE "MaTable" ADD "ColonneDate"
     DATE DEFAULT  NULL
    Re copie des données:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    UPDATE "MaTable" set "ColonneDate"=TEMP_DATE;
    et finalement effacement de la colonne temporaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alter table "MaTable" drop TEMP_DATE
    Voilà. Sinon il existe une méthode plus courte mais il faut trifouiller dans les les tables systeme. On peux l'utiliser si la colonne est liée à d'autres objets..
    Ajout d'une colonne temporaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ALTER TABLE "MaTable" ADD TEMP_DATE
     DATE DEFAULT Null
    Changement des tables systemes pour attribuer la valeur par Defaut créée pour TEMP_DATE à ColonneDate (la colonne date d'origine qui n'a pas de valeur par defaut) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    UPDATE RDB$RELATION_FIELDS F1 SET F1.RDB$DEFAULT_VALUE  = (SELECT F2.RDB$DEFAULT_VALUE
                                                               FROM RDB$RELATION_FIELDS F2
                                                               WHERE (F2.RDB$RELATION_NAME = 'MaTable') AND
                                                                     (F2.RDB$FIELD_NAME = 'TEMP_DATE')),
                                      F1.RDB$DEFAULT_SOURCE = (SELECT F3.RDB$DEFAULT_SOURCE FROM RDB$RELATION_FIELDS F3
                                                               WHERE (F3.RDB$RELATION_NAME = 'MaTable') AND
                                                                     (F3.RDB$FIELD_NAME = 'TEMP_DATE'))
                                      WHERE (F1.RDB$RELATION_NAME = 'MaTable') AND
                                            (F1.RDB$FIELD_NAME = 'ColonneDate')
    Effacement de la colonne temporaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER TABLE "MaTable" DROP TEMP_DATE

  4. #4
    Membre éprouvé
    Avatar de Andry
    Profil pro
    Informaticien
    Inscrit en
    Juillet 2002
    Messages
    1 164
    Détails du profil
    Informations personnelles :
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 164
    Par défaut
    Merci Barbibulle.
    Ca marche la solution n° 1 car les champs ne sont pas lié ni indexé.

    Merci

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

Discussions similaires

  1. Quick Report et impression de données hors BDD
    Par gRRosminet dans le forum C++Builder
    Réponses: 8
    Dernier message: 19/08/2002, 09h47
  2. portabilité et BDD
    Par delire8 dans le forum C++Builder
    Réponses: 7
    Dernier message: 04/07/2002, 10h59
  3. connection a une BDD MySql
    Par delire8 dans le forum MFC
    Réponses: 7
    Dernier message: 19/06/2002, 18h18
  4. [BDD] Enregistrer le résultat d'une requête
    Par Mowgly dans le forum C++Builder
    Réponses: 5
    Dernier message: 19/06/2002, 15h26
  5. Probleme de filtre dans bdd
    Par scorpiwolf dans le forum C++Builder
    Réponses: 2
    Dernier message: 04/06/2002, 10h43

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