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

PL/SQL Oracle Discussion :

Comment mettre un zéro devant un number style 02 au lieu de 2 ?


Sujet :

PL/SQL Oracle

  1. #1
    Membre du Club
    Inscrit en
    Juin 2005
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 139
    Points : 59
    Points
    59
    Par défaut Comment mettre un zéro devant un number style 02 au lieu de 2 ?
    Bonjour à toutes et à tous

    J'ai une fonction ou je veux rajouter un zero devant un chiffre mais je n'arrive pas.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    CREATE OR REPLACE Function renvoiNumber( numero IN NUMBER ) RETURN number
    IS
       df number;
    BEGIN
      if numero <10 THEN
        df :=LPAD(numero, 2, 0);
      else
        df:=numero;
      end if;
    RETURN df;
    END;
    /
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select renvoiNumber(5) from dual;
    cette requete est censée me renvoyer 05 au lieu de 5.
    je vois qu'il y'a une hsitoire de conversion mais je ne vois pas ce qu'il faut faire.
    dans tous les cas je dois renoyer un number.
    Merci

  2. #2
    Membre éclairé Avatar de bstevy
    Homme Profil pro
    Solutions Architect
    Inscrit en
    Mai 2009
    Messages
    552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Japon

    Informations professionnelles :
    Activité : Solutions Architect
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2009
    Messages : 552
    Points : 870
    Points
    870
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select to_char(2,'00') from dual
    Mais 02, c'est pas un number, c'est un char.
    Donc faut décider si vous voulez 02 en char ou 2 en number

  3. #3
    Membre du Club
    Inscrit en
    Juin 2005
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 139
    Points : 59
    Points
    59
    Par défaut
    Peut etre que j'ai pris une mauvaise direction mais comment faire pr renvoyer 01 ou 02 jusqu'a 09? y'a t'il une autre methode?
    Le but final est d'inserer dans un champ de type number la valeur 01 ou 02 ou 03 ...09.
    Merci

  4. #4
    Expert éminent sénior 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
    Points : 11 252
    Points
    11 252
    Par défaut
    Un nombre n'a pas des zéros non-significatives devant.

  5. #5
    Membre à l'essai
    Homme Profil pro
    Analyse système
    Inscrit en
    Juillet 2015
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Brésil

    Informations professionnelles :
    Activité : Analyse système

    Informations forums :
    Inscription : Juillet 2015
    Messages : 14
    Points : 20
    Points
    20
    Par défaut
    Le plus logique c'est de traité le donné seulement quand il est nécessaire.

    Si le champ est NUMBER donc n'importe combien de zeros tu va mettre devant, les zeros à gauche valent rien.

    Si vous voulez insérer le '02' , pas le nombre '2' , il faut que ton champ doit être VARCHAR. Mais c'est idiot d'avoir un champ varchar pour stoker des nombres. Fréquemment quand ça arrive c'est un mauvais usage des structures des donnés.

  6. #6
    Membre confirmé
    Homme Profil pro
    xxxxxxxxx
    Inscrit en
    Avril 2015
    Messages
    393
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : xxxxxxxxx

    Informations forums :
    Inscription : Avril 2015
    Messages : 393
    Points : 552
    Points
    552
    Par défaut fonction_renvoie_deux_caracteres
    voici un léger changement de ta fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    CREATE OR REPLACE Function renvoiNumber( numero IN NUMBER ) RETURN varchar2
    IS
       df varchar2(2);
    BEGIN
      if numero <10 THEN
        df :=LPAD(numero, 2, 0);
      else
        df:=numero;
      end if;
    RETURN df;
    END;
    /

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 31/08/2009, 17h05
  2. Comment supprimer les "zéros" devant une variable
    Par solorac dans le forum Excel
    Réponses: 4
    Dernier message: 16/05/2008, 23h14
  3. Réponses: 10
    Dernier message: 08/08/2006, 14h23
  4. [linux] mettre des zéros devant un nombre
    Par le mage tophinus dans le forum C
    Réponses: 15
    Dernier message: 04/10/2005, 08h26

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