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 :

Afficher 001 au lieu de 1


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Inscrit en
    Janvier 2008
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 8
    Par défaut Afficher 001 au lieu de 1
    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!

  2. #2
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    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

  3. #3
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Citation Envoyé par vicenzo Voir le message
    ...
    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
    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 Lpad fonctionne parce que Oracle applique une coercition: un to_char implicite.
    Donc il est préférable d'utiliser le to_char explicite.

  4. #4
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Donc Lpad fonctionne parce que Oracle applique une coercition: un to_char implicite.
    Quelqu'un aurait prétendu le contraire ?
    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

  5. #5
    Membre régulier
    Inscrit en
    Janvier 2008
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 8
    Par défaut
    ok merci, j'essaie ça dans la matinée, je vous tiens au courant

  6. #6
    Membre régulier
    Inscrit en
    Janvier 2008
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 8
    Par défaut
    ca marche nickel. thanks dudes
    ++

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

Discussions similaires

  1. Afficher "Annexes" au lieu de "Chapitre"
    Par Dan_coyle dans le forum Mise en forme
    Réponses: 19
    Dernier message: 19/05/2009, 16h52
  2. [XL-2007] Affiche entier au lieu de décimaux
    Par chouki60 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 14/04/2009, 08h53
  3. Afficher "Vrai" au lieu de True
    Par Tiken dans le forum Bases de données
    Réponses: 5
    Dernier message: 22/10/2008, 18h20
  4. Afficher é au lieu de é dans un textarea
    Par bucky3325 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 6
    Dernier message: 22/12/2006, 13h42
  5. PB SYSDATE, par ex : affiche 04h00 au lieu 16h00
    Par wormseric dans le forum Oracle
    Réponses: 4
    Dernier message: 06/10/2006, 17h55

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