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 :

Remplacer un chaine en utilisant un caractère générique


Sujet :

Langage SQL

  1. #1
    Candidat au Club
    Inscrit en
    Août 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Remplacer un chaine en utilisant un caractère générique
    Bonjour,

    Je souhaiterai remplacer la fin d'une chaine par un vide (donc la tronquer )à partir d'une certaine chaine de caractère (ici ".jpg") mais cette requette ne fonctionne pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    UPDATE `ma_table`  
    SET mon_champs =  REPLACE( mon_champs, '.jpg%', '.jpg')
    Pour plus de détails, j'ai les adresses de mes images dans le champs "images" de ma table. Cette table provient d'un ancien site et à la suite des adresses il y a des caractères que je souhaite retirer .

    par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    http://monsite.fr/image/monImage.jpg|||0|bottom|
    et je souhaite obtenir :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    http://monsite.fr/image/monImage.jpg
    Je connais la fonction Left() mais dans ce cas le nombre de caractère peut varier donc ce n'est pas utilisable.

    Merci d'avance

    Morko

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Si votre SGBD est MySQL, vous pouvez utiliser la fonction INSTR pour trouver la bonne longueur.

  3. #3
    Candidat au Club
    Inscrit en
    Août 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Merci
    Merci beaucoup,

    voici la correction si certain on le même problème


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE `ma_table`
    SET mon_champ = LEFT( mon_champ, INSTR( mon_champ, '.jpg') + 3)

    et voici les prototype des fonction LEFT et INSTR

    LEFT ( chaine, n )

    'chaine' une chaine de caractère
    'n' un entier positif ou null

    retourne une chaine correspondant au n premier caractère de chaine

    exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    LEFT ('abcdefghijk', 5)
    renvoi 'abcde'


    INSTR(chaine, expression)

    'chaine' une chaine de caractère
    'expression' une chaine de caractère

    retourne un entier correspondant à la position du premier caractère de la première occurrence de expression dans chaine

    exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSTR('abcdefghijk', 'efg')
    renvoi 5

    voila

    encore merci Waldar

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

Discussions similaires

  1. Requêtes : utilisation de caractères génériques
    Par pigac dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 16/02/2012, 19h32
  2. Réponses: 4
    Dernier message: 10/07/2007, 15h17
  3. Réponses: 4
    Dernier message: 18/07/2006, 16h31
  4. Non-utilisation d'un caractère générique
    Par ehrhart.jy dans le forum Access
    Réponses: 2
    Dernier message: 13/07/2006, 11h02
  5. caractère générique utilisable dans strcmp
    Par barthelv dans le forum C
    Réponses: 9
    Dernier message: 01/08/2003, 16h54

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