Précédent   Forum des professionnels en informatique > Bases de données > PostgreSQL
PostgreSQL Forum PostgreSQL. Avant de poster -> F.A.Q PostGreSQL Tutoriels PostGreSQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 25/10/2004, 14h43   #1
Candidat au titre de Membre du Club
 
Inscription : avril 2004
Messages : 28
Détails du profil
Informations forums :
Inscription : avril 2004
Messages : 28
Points : 12
Points : 12
Envoyer un message via MSN à xopos
Par défaut modifier le type d'un champs

bonjour,

j'aimerais savoir s'il est possible de modifier le type de données de d'un champs... si oui comment?

par exemple d'un champs de type date, j'aimerais le mettre en chaine!

Merci
xopos est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/10/2004, 17h28   #2
Membre émérite
 
Avatar de hpalpha
 
Inscription : mars 2002
Messages : 770
Détails du profil
Informations forums :
Inscription : mars 2002
Messages : 770
Points : 833
Points : 833
Oui il est possible (a condition que les types de données soient compatibles)


Voici un exemple de requete SQL, qui transforme monchamp en varchar :

Code :
ALTER TABLE "public"."matable" ALTER COLUMN "monchamp" TYPE VARCHAR
hpalpha est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/11/2004, 18h11   #3
Candidat au titre de Membre du Club
 
Inscription : août 2004
Messages : 30
Détails du profil
Informations forums :
Inscription : août 2004
Messages : 30
Points : 14
Points : 14
Signaler que le pb est résolu ;)
++
Jul.
bdkiller est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 10/12/2007, 16h48   #4
Membre du Club
 
Inscription : septembre 2006
Messages : 72
Détails du profil
Informations forums :
Inscription : septembre 2006
Messages : 72
Points : 55
Points : 55
Marche pas chez moi, il m'indique une erreur de syntaxe près de TYPE...

Pour une conversion d'un champ CHAR vers VARCHAR
big_ben3333 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 10/12/2007, 16h59   #5
Membre émérite
 
Avatar de hpalpha
 
Inscription : mars 2002
Messages : 770
Détails du profil
Informations forums :
Inscription : mars 2002
Messages : 770
Points : 833
Points : 833
normalement char et varchar sont 2 types compatibles, donc ca devrait passer, quel version de pg utilise tu ? (avant 8 ca marchait pas de memoire)

peut tu mettre ta requete ?
hpalpha est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/12/2007, 14h46   #6
Membre du Club
 
Inscription : septembre 2006
Messages : 72
Détails du profil
Informations forums :
Inscription : septembre 2006
Messages : 72
Points : 55
Points : 55
La seule solution que j'ai trouvée pour postGreSQL 7.4 est de faire un dump de la table, de la supprimer, de modifier la structure dans le dump et de l'executer.

Merci à vous
big_ben3333 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/12/2008, 19h28   #7
Invité de passage
 
Inscription : mai 2008
Messages : 7
Détails du profil
Informations forums :
Inscription : mai 2008
Messages : 7
Points : 1
Points : 1
Par défaut pb avec vue

ALTER TABLE monshema.matable ALTER COLUMN monchamps TYPE monnouveautype

Cette solution ne fonctionne pas lorsqu'on a des vues qui utilisent le champ qu'on souhaite modifier.
J'ai le message : ERROR: cannot alter type of a column used by a view or rule

Y'a t'il un moyen de modifier le type d'un champ simplement (passer d'un réel à un double précision par exemple), y compris pour des champs utilisés dans des vues ?

Merci de votre aide.
medsine est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/12/2008, 15h09   #8
Rédacteur/Modérateur

 
Avatar de SQLpro
 
Homme Frédéric BROUARD
Expert SGBDR & SQL
Inscription : mai 2002
Messages : 10 959
Détails du profil
Informations personnelles :
Nom : Homme Frédéric BROUARD
Localisation : France

Informations professionnelles :
Activité : Expert SGBDR & SQL
Secteur : Conseil

Informations forums :
Inscription : mai 2002
Messages : 10 959
Points : 17 791
Points : 17 791
Citation:
Y'a t'il un moyen de modifier le type d'un champ simplement (passer d'un réel à un double précision par exemple), y compris pour des champs utilisés dans des vues ?
Non ! Les objets étant interdépendant, le changement d'un type provoquera des erreurs dans les autres objets. C'est pour cela que la norme SQL interdit ce type de commande.
Néanmoins, certains SGBDR permettent ce genre de choses avec toutes les conséquences que cela peut avoir ensuite.

Une solution plus intelligente consiste à élaborer un script SQL de modification de schéma.
Vous pouvez vous inspirer de celui que j'ai écrit ici :
http://sqlpro.developpez.com/cours/s...partie2#L7.6.1

Cependant le moyen le plus rapide et le plus intelligent est d'utiliser un outil de modélisation de données comme Power AMC, qui permet de générer automatiquement des script SQL de delta schéma entre les différentes versions de votre modèle de données.

A +
__________________
Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
Site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
Blog SQL, SQL Server, modélisation données : http://blog.developpez.com/sqlpro
http://www.sqlspot.com : modélisation, conseils, audit, optimisation, formation
* * * * * Enseignant CNAM PACA - ISEN Toulon - CESI Aix en Provence * * * * *
SQLpro est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h12.


 
 
 
 
Partenaires

Hébergement Web