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

Requêtes et SQL. Discussion :

supprimer le premier caractere d'une chaine


Sujet :

Requêtes et SQL.

  1. #1
    Membre régulier Avatar de alexkickstand
    Inscrit en
    Octobre 2002
    Messages
    165
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 165
    Points : 105
    Points
    105
    Par défaut supprimer le premier caractere d'une chaine
    bonjour, j'ai fais une requete pour supprimer le premier caractere d'une chaine de caractere si la chaine de caractere commence par 'R'.

    mais j'ai un probleme : si une chaine de caractere est plus longue q'une autre il m'enleve les 2 premiers caracteres :

    code de la requete

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    UPDATE tbl_query SET matable.Produit = Right(matable.Item,9)
    WHERE matable.Item Like 'R*';
    mon erreur viens surement de "Right(matable.Item,9)"

    exemple j'ai une chaine de caractere :

    R008102531 apres la requete j'ai bien 008102531 (1 caractere enlevé)
    et une autre
    R008102531G apres la requete j'ai 08102531G (2 caracteres enlevé)

    en résumé je souhaiterais enlevé le R en début de chaque chaine de caractere si elles contient bien un R en début

    merci pour de l'aide

    Alex

  2. #2
    Membre chevronné
    Avatar de Demco
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    1 396
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 1 396
    Points : 2 228
    Points
    2 228
    Par défaut
    Utilise la fonction len() à l'intérieur de la fonction Right().

    En espérant t'aider.

  3. #3
    Membre régulier Avatar de alexkickstand
    Inscrit en
    Octobre 2002
    Messages
    165
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 165
    Points : 105
    Points
    105
    Par défaut re
    merci pour ta réponse mais j'ai de la misere pour définir comment enlever uniquement la premiere lettre (niveau syntaxe)

    merci de ton aide

    Alex

  4. #4
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    rigth(machaine,len(machaine)-1)

  5. #5
    Membre régulier Avatar de alexkickstand
    Inscrit en
    Octobre 2002
    Messages
    165
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 165
    Points : 105
    Points
    105
    Par défaut
    Citation Envoyé par random Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    rigth(machaine,len(machaine)-1)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    UPDATE tbl_query SET matable.Produit = right(matable.Produit,len(matable.Produit)-1)
    WHERE tbl_query.Item Like 'R*';
    il me retourne juste un caractere apres la requete "0" ou "1"

    ca me laisse pas mal perplexe

    Alex

  6. #6
    Membre actif Avatar de spaiku
    Homme Profil pro
    Consultant fonctionnel
    Inscrit en
    Septembre 2007
    Messages
    209
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Eure et Loir (Centre)

    Informations professionnelles :
    Activité : Consultant fonctionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2007
    Messages : 209
    Points : 293
    Points
    293
    Par défaut
    Les fonctions len et right sont du vba. Il faut que tu les sépares de ton sql.

    Tu peux par exemple récupérer la valeur de ta table dans une variable, la transformer avec len et right, et la remettre dans ta requête sql.

    Tu peux aussi t'amuser à tout insérer sur la même ligne en coupant ta chaîne et en concaténant les fonctions, mais ce sera nettement moins lisible.

  7. #7
    Membre régulier Avatar de alexkickstand
    Inscrit en
    Octobre 2002
    Messages
    165
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 165
    Points : 105
    Points
    105
    Par défaut
    ok merci de ton aide je vais travailler dessus

    merci !!!

    Alex

  8. #8
    Membre chevronné
    Avatar de Demco
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    1 396
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 1 396
    Points : 2 228
    Points
    2 228
    Par défaut
    Citation Envoyé par spaiku Voir le message
    Les fonctions len et right sont du vba. Il faut que tu les sépares de ton sql.
    Tu peux utiliser les fonction VBA directement dans ton code SQL avec MS Access. Tu peux même créer ta propre fonction et l'utiliser dans le code SQL.

    Le code que random t'a donné devrait fonctionner (comme d'hab).
    Créé un jeu de test, applique la requête de random et observe le résultat.

  9. #9
    Membre régulier Avatar de alexkickstand
    Inscrit en
    Octobre 2002
    Messages
    165
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 165
    Points : 105
    Points
    105
    Par défaut re
    j'ai suivis vos conseil de fonction puis j'ai fais ca et ca fonctionne bien

    il me reste plus qu'a ajouter la condition que la chaine de caractere doit commencer par "R" pour utiliser la fonction

    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
     
    Function test()
     
     Dim dbs As Database
     Dim rst As Recordset
     'Dim test As Integer
       Set dbs = CurrentDb
       Set rst = dbs.OpenRecordset("matable")
     
     With rst
     
           Do While Not .EOF
     
                .Edit
                !produit = Right(!produit, Len(!produit) - 1)
     
                .Update
     
              .MoveNext
            Loop '.EOF
         .Close
     
       End With
     
       dbs.Close
     
    End Function
    merci de votre aide a tous

    Alex

  10. #10
    Membre régulier Avatar de alexkickstand
    Inscrit en
    Octobre 2002
    Messages
    165
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 165
    Points : 105
    Points
    105
    Par défaut re
    voici la fonction avec la condition que la chaine commence par "R"

    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
     
    Function test()
     
     Dim dbs As Database
     Dim rst As Recordset
     'Dim test As Integer
       Set dbs = CurrentDb
       Set rst = dbs.OpenRecordset("matable")
     
     With rst
     
           Do While Not .EOF
     
                .Edit
                If !produit Like "R*" Then
     
                !produit = Right(!produit, Len(!produit) - 1)
     
              Else
     
              MsgBox ("pas de r")
     
              End If
     
                .Update
     
              .MoveNext
            Loop '.EOF
         .Close
     
       End With
     
       dbs.Close
     
    End Function

  11. #11
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    Mon dieu!

    alexkickstand désolé d'arrivée après l'extinction des feux.

    random t'avais mis sur la piste: il fallait juste rajouter une fonction VraiFaux()=Iif
    j'utilise une subtilité pour l'éviter dans mon ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT MaTable.MOT, Right([MOT],Len([MOT])+(Left([MOT],1)="R")) AS M FROM MaTable;

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

Discussions similaires

  1. Extraire le premier caractere d'une chaine de caractere
    Par Shikamaru86 dans le forum C++Builder
    Réponses: 6
    Dernier message: 21/09/2006, 09h14
  2. Supprimer le premier caractere d'une chaine
    Par Jim_Nastiq dans le forum Langage
    Réponses: 2
    Dernier message: 06/04/2006, 16h40
  3. Réponses: 6
    Dernier message: 17/10/2005, 14h38
  4. Supprimer le premier caractère d'une chaine de caractères
    Par Droïde Système7 dans le forum Langage
    Réponses: 2
    Dernier message: 30/09/2005, 11h13
  5. [langage] Retirer le premier caractère d'une chaine ?
    Par kwisach dans le forum Langage
    Réponses: 5
    Dernier message: 24/04/2003, 11h05

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