Bonjour,
ma question est dans le titre:
comment définir un type numérique qui m'affiche les nombres/chiffres sur une certaine longueur en comblant avec des zéros?
X=4
donc
1 sera 0001
X=6
donc
12 sera 000012
avez-vous une solution?
Merci!![]()
Bonjour,
ma question est dans le titre:
comment définir un type numérique qui m'affiche les nombres/chiffres sur une certaine longueur en comblant avec des zéros?
X=4
donc
1 sera 0001
X=6
donc
12 sera 000012
avez-vous une solution?
Merci!![]()
C'est tout bêtement impossible...
Un nombre est un nombre et n'est donc par définition pas un chaîne de caractères !
Encore une confusion de genres !
Ajouter des zéros implique une notion de chaîne de caractères.
donc, si tu veux pouvoir récupérer une chaine de caractères avec un padding de zéros devant, tu peux faire un lpad(n, x, '0') ou un to_char(n, '09999') par exemple pour padder sur 5 caractères
Vincent Rogier.
Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog
Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !
OCILIB (C Driver for Oracle)
Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle
Donc Lpad fonctionne parce que Oracle applique une coercition: un to_char implicite.LPAD(expr1, n [, expr2 ])
LPAD returns expr1, left-padded to length n characters with the sequence of characters in expr2. This function is useful for formatting the output of a query.
Both expr1 and expr2 can be any of the datatypes CHAR, VARCHAR2, NCHAR, NVARCHAR2, CLOB, or NCLOB. The string returned is of VARCHAR2 datatype if expr1 is a character datatype and a LOB if expr1 is a LOB datatype. The string returned is in the same character set as expr1. The argument n must be a NUMBER integer or a value that can be implicitly converted to a NUMBER integer.
If you do not specify expr2, then the default is a single blank. If expr1 is longer than n, then this function returns the portion of expr1 that fits in n.
Donc il est préférable d'utiliser le to_char explicite.
Vincent Rogier.
Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog
Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !
OCILIB (C Driver for Oracle)
Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle
ok merci, j'essaie ça dans la matinée, je vous tiens au courant
ca marche nickel. thanks dudes
++
Partager