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

C# Discussion :

Convertir un chiffre en mois


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Août 2009
    Messages
    273
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 273
    Par défaut Convertir un chiffre en mois
    Bonjour,

    Je voudrais convertir un chiffre en mois (ex : 2 --> février). Pour celà,
    j'ai crée un fonction que j'ai appelée ConvertirEnMois.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
     
    public static string ConvertirEnMois(int Nombre)
            {
                switch (Number)
                {
                    case 1:
                    return "Janvier";
     
                    case 2:
                    return "Février";
     
                    case 3:
                    return "Mars";
     
                    case 4:
                    return "Avril";
     
                    case 5:
                    return "Mai";
     
                    case 6:
                    return "Juin";
     
                    case 7:
                    return "Juillet";
     
                    case 8:
                    return "Août";
     
                    case 9:
                    return "Septembre";
     
                    case 10:
                    return "Octobre";
     
                    case 11:
                    return "Novembre";
     
                    case 12:
                    return "Décembre";
     
                    default:
                    return "Mois inconnu";
                }
            }
    Dans mon code, je fais un select dans lequel je voudrais récupérer un champs de type entier de longueur 6 chiffres (ex: 200802) et extraire les
    2 derniers chiffres qui correspondent au mois.

    Donc, je fais:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    "select champs1, champs2, champs3, " + ConvertirEnMois(champs4)
    Ce que je n'arrive pas à faire c'est utiliser le substr dans mon code c# pour extraire les 2 derniers chiffres de la valeur du champs4 alors que j'ai testé ma requête

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select substr(200802,5) from dual
    dans l'outil sql que j'utilise et ça fonctionne très bien.

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    122
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 122
    Par défaut
    Citation Envoyé par Jinkas Voir le message
    Ce que je n'arrive pas à faire c'est utiliser le substr dans mon code c# pour extraire les 2 derniers chiffres de la valeur du champs4
    Bonjour,

    1. Tu peux mettre la ligne de code qui correspond à ce que tu récupères du champ 4 ?

    2. Tu as essayé en mode debug pour voir la valeur que tu récupères ? Tu as quoi précisément ?

  3. #3
    Membre éclairé
    Inscrit en
    Août 2009
    Messages
    273
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 273
    Par défaut
    J'ai essayé celà
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    "SELECT CHAMPS1, CHAMPS2, CHAMPS3, " + ConvertirEnMois(+ " substr(champs4,5) " ) +
    mais aussi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    "SELECT CHAMPS1, CHAMPS2, CHAMPS3, " + ConvertirEnMois(+ " cast(substr(champs4,5)) as int " ) +
    et

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    "SELECT CHAMPS1, CHAMPS2, CHAMPS3, " + ConvertirEnMois(2) +
    Aucun fonctionne!

  4. #4
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Déjà, pour ta conversion, pourquoi faire simple quand on peut faire compliqué ?

    Quand même moins tarabiscoté :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
            static string monthFromNumber(int iMonth)
            {
                return DateTime.ParseExact(iMonth.ToString("00"), "MM", CultureInfo.CurrentCulture).ToString("MMMM");
            }
    Ensuite, je ne comprends pas ce que tu essaye de faire : à moins d'utiliser du SQL CLR (Sql Server uniquement), tu ne peux évidemment pas appeler une fonction .Net depuis le SQL.

    Par ailleurs, c'est étrange de demander à SQL d'effectuer une transformation comestique de données, ce n'est pas son job. Pourquoi ne transforme tu pas cela au moment de l'affichage ?

  5. #5
    Membre éclairé
    Inscrit en
    Août 2009
    Messages
    273
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 273
    Par défaut
    comment l'utiliser dans la requête car j'essaie ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    = " select champs1, champs2, champs3, " + monthFromNumber(+ " champs4 " + ) +
    ça ne fonctionne pas

  6. #6
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par Jinkas Voir le message
    comment l'utiliser dans la requête car j'essaie ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    = " select champs1, champs2, champs3, " + monthFromNumber(+ " champs4 " + ) +
    ça ne fonctionne pas
    Tu lis les réponses qu'on te fait ?????

    à moins d'utiliser du SQL CLR (Sql Server uniquement), tu ne peux évidemment pas appeler une fonction .Net depuis le SQL.

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

Discussions similaires

  1. [Vxi] Convertir un mois en chiffre à un mois en lettres
    Par Burt67 dans le forum Webi
    Réponses: 3
    Dernier message: 04/06/2010, 08h34
  2. Convertir un chiffre de 0 à 1 en string
    Par dodineau dans le forum Windows Forms
    Réponses: 2
    Dernier message: 13/02/2007, 08h26
  3. [WD10] Code pour convertir les chiffres en lettres
    Par w-cobra dans le forum WinDev
    Réponses: 10
    Dernier message: 24/01/2007, 16h56
  4. Convertir un chiffre avec virgul en nombe entier
    Par delavega dans le forum ASP
    Réponses: 1
    Dernier message: 03/10/2006, 11h32
  5. possible convertir un chiffre en lettre avec builder ?
    Par devlopassion dans le forum C++Builder
    Réponses: 8
    Dernier message: 11/09/2006, 17h24

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