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 :

Comment DELETE une chaine ?


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 18
    Points : 13
    Points
    13
    Par défaut Comment DELETE une chaine ?
    Bonjour,
    je souhaiterai effacer une suite de code html dans un script qui est placé dans tous les champs d'une de mes colones :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    script dans la_colone
    
    <p>Repassage sur l'envers </p><p>&nbsp;</p></td></tr></tbody></table>
    Je dois utiliser la commande DELETE,
    quelle serait la syntaxe pour que DELETE n'efface que cette chaine de code???

    cette requette est elle valable ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE la_table
    SET la_colone=DELETE(la_colone,'<p>&nbsp;</p></td></tr></tbody></table>')

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    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 080
    Points : 30 803
    Points
    30 803
    Par défaut
    Quel est le SGBD qui utilise cette fonction DELETE ?
    Elle semble inconnue de la norme
    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
    Membre expérimenté
    Avatar de Bloon
    Homme Profil pro
    Consultant Freelance
    Inscrit en
    Avril 2002
    Messages
    467
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant Freelance
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2002
    Messages : 467
    Points : 1 339
    Points
    1 339
    Par défaut
    DELETE sert à supprimer des lignes, tu as plutôt besoin d'une fonction de remplacement d'une chaîne par une autre. Exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE la_table
    SET la_colone=REPLACE(la_colone,'<p>&nbsp;</p></td></tr></tbody></table>','')
    En remplaçant ta chaîne par la chaîne vide, ça la supprime de la chaîne d'origine.

    Bloon
    A lire : Les règles du club
    Delphi : La FAQ - Articles

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 18
    Points : 13
    Points
    13
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    10 CLS
    20 PRINT "Mille MERCI les gars !!!"
    30 i=i+1
    40 IF i=1000 THEN GOTO 60
    50 GOTO 10
    60 END
    Juste un truc, lors d'une autre erreur de frappe (clonée 1000 fois), je cherche à suprimer seulement les 3 derniers caractères d'une ligne (<p> que l'on retrouve un peu partout dans la cellule editée
    Quelle condition dois je utiliser pour enlever ces 3 derniers caractères uniquement ???

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    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 080
    Points : 30 803
    Points
    30 803
    Par défaut
    Il suffit de retirer 3 caractères à la longueur de la chaine quand elle se termine par '<p>'
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE la_table
    SET la_colonne = SUBSTRING(la_colonne FROM 1 FOR CHARACTER_LENGTH(TRIM(la_colonne) - 3))
    WHERE SUBSTRING(la_colonne FROM CHARACTER_LENGTH(TRIM(la_colonne) - 3) FOR 3) = '<p>'
    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
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Citation Envoyé par melix1 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    10 CLS
    20 PRINT "Mille MERCI les gars !!!"
    30 i=i+1
    40 IF i=1000 THEN GOTO 60
    50 GOTO 10
    60 END
    Wow ! Du bon vieux Basic des années 80 !

    J'aurais quand même fait une boucle FOR :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    10 CLS
    20 FOR i = 1 TO 1000 STEP 1
    30 PRINT "Mille MERCI les gars !!!"
    30 NEXT i
    40 END
    A l'époque il fallait économiser le moindre caractère dans les programmes.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 18
    Points : 13
    Points
    13
    Par défaut
    Alors la !!!
    j'avoue que cette requette me dépasse !!!
    bon , la boucle en basic, passe encore... mais le SUBSTRING et ses acolytes...

    MERCI vous êtes super géniaux !!!

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 03/10/2005, 16h23
  2. Comment surligner une chaine dans un RichEdit
    Par esteban63 dans le forum Composants VCL
    Réponses: 2
    Dernier message: 12/09/2005, 00h33
  3. Réponses: 2
    Dernier message: 14/01/2005, 15h40
  4. [Property] Comment déclarer une chaine par defaut ?
    Par Clorish dans le forum Composants VCL
    Réponses: 8
    Dernier message: 07/09/2004, 22h11
  5. comment vider une chaine de caractère
    Par gaut dans le forum C
    Réponses: 13
    Dernier message: 12/09/2003, 11h30

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