Modifier champs base mysql

Résolu
t671 Messages postés 1476 Date d'inscription   Statut Membre Dernière intervention   -  
t671 Messages postés 1476 Date d'inscription   Statut Membre Dernière intervention   -

Bonjour,

Je cherche à modifier les enregistrements d'une colonne d'une base de donnée.

Les enregistrements sont composés de 2 à 5 chiffres. Je voudrais y rajouter 000 à chaque enregistrement de la colonne.

J'ai tenté plusieurs façons, dont :

UPDATE malfoi SET num_indiv = REPLACE (num_indiv,"%","%000") where num_indiv like "%"

Mais cela ne modifie aucun enregistrement, sans message d'erreur.

Merci

A voir également:

2 réponses

jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 

Bonjour,

Si ton champ ne contient que des nombres ( ce qui semble être le cas), tu as certainement du déclarer ta colonne en INT ou DECIMAL ou FLOAT ..  bref.. un champ de type numérique. ( et c'est bien ce qu'il faut faire)

Toi, tu veux "formater" le champ en ajoutant des "0" superflus devant .....  et .. ben...  ça .. tu peux le faire lors de l'affichage via ton programme. Aucun intéret de stocker la donnée dans ce format dans la base.. (d'ailleurs tu ne pourrais pas... à moins de changer ton champ en "varchar" .. mais ça serait une grosse ânerie.. )

Ne confonds pas la base de données qui sert juste à stocker les données ( sans aucun "format" .. ) .. et ton programme externe ( en php par exemple) qui te sert à exploiter ces données.


0
t671 Messages postés 1476 Date d'inscription   Statut Membre Dernière intervention   11
 

Merci jordane45.

Mon champ est bien en DECIMAL. Les "0", je souhaite les ajouter derrière.

26 devient 26000

2547 devient 2547000 ............

Tout ça parce que j'ai d'autres tables sur le même format, et après la fusion des tables, je ne veux pas avoir de num_indiv identique

0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584
 

bonjour,

as-tu envisagé la multiplication?

0
jee pee Messages postés 41553 Date d'inscription   Statut Modérateur Dernière intervention   9 725
 

salut, donc il suffit de multiplier par 1000

SET num_indiv = num_indiv * 1000
0
t671 Messages postés 1476 Date d'inscription   Statut Membre Dernière intervention   11 > jee pee Messages postés 41553 Date d'inscription   Statut Modérateur Dernière intervention  
 

Si je fais 

UPDATE malfoi SET num_indiv = 'num_indiv * 1000'

tous les num_indiv se mettent à 0 !!!!???

0
t671 Messages postés 1476 Date d'inscription   Statut Membre Dernière intervention   11 > jee pee Messages postés 41553 Date d'inscription   Statut Modérateur Dernière intervention  
 

J'ai trouvé

UPDATE malfoi SET num_indiv = num_indiv * 1000

Merciiiii

0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 584
 

Ne serait-ce pas plus propre d'ajouter 100.000 à chaque nombre?

26 deviendrait 100.026
2547 deviendrait 102.547

0