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

Langage SQL Discussion :

manipulation complexe de champ


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de PAYASS59
    Homme Profil pro
    Inscrit en
    Février 2005
    Messages
    755
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Février 2005
    Messages : 755
    Par défaut manipulation complexe de champ
    Bonjour,

    j'ai un champ qu'on appelera numero pour l'exemple.

    exemple :
    numero
    12589
    236
    87422
    5896214
    125
    ....

    Je voudrai avec un select transformer ces numeros en commencant par 51 suivi de autant de 0 afin d'arriver a une longueur de 15.

    résultat
    510000000012589
    510000000000236
    510000000087422
    510000005896214
    510000000000125

    merci d'avance pour vos reponses.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Quelque chose comme ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SUBSTRING('51000000000000' FROM 1 
       FOR 15 - CHAR_LENGTH(TRIM(CAST(numero AS CHAR(13))))) 
    || TRIM(CAST(numero AS CHAR(13)))
    Si ton SGBD a une fonction LOG, tu peux remplacer CHAR_LENGTH(TRIM(CAST(numero AS CHAR(13)))) par LOG(numero) + 1
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Utilise la fonction LPAD, ça rempli un string du caractère spécifié par la gauche jusqu'à la longueur spécifiée.

    LPAD(nom_colonne, longueur, caractère)

    Ex: '51' + LPAD(Numéro, 13, '0')
    NB: Pour Oracle, remplace le + par ||

    Yroubag

  4. #4
    Membre éclairé Avatar de PAYASS59
    Homme Profil pro
    Inscrit en
    Février 2005
    Messages
    755
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Février 2005
    Messages : 755
    Par défaut
    merci pour vos réponses rapides....

    la solution de yroubag fonctionne tres bien....

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    La fonction LPAD est en effet fort pratique, mais elle n'appartient pas à la norme du langage SQL et, de ce fait, n'est pas prise en charge par tous les SGBD.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  6. #6
    Membre éclairé Avatar de PAYASS59
    Homme Profil pro
    Inscrit en
    Février 2005
    Messages
    755
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Février 2005
    Messages : 755
    Par défaut
    merci de ces précisions...

    je m'en souviendrai un jour...

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 27/03/2015, 17h47
  2. Problème de manipulation avec un champ Label
    Par Minos2 dans le forum Apple
    Réponses: 2
    Dernier message: 19/01/2010, 14h30
  3. manipulation d un champ de type datetime
    Par decisionnel dans le forum Langage SQL
    Réponses: 3
    Dernier message: 23/07/2009, 09h14
  4. question requete complexe sur champ varchar
    Par pazgal dans le forum Langage SQL
    Réponses: 20
    Dernier message: 14/10/2008, 17h09
  5. manipulation d'un champ de type Memo
    Par ivanleterrible dans le forum Bases de données
    Réponses: 6
    Dernier message: 29/05/2006, 21h53

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