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

Développement SQL Server Discussion :

Faire un update avec resultat différent par rapport à l'ID


Sujet :

Développement SQL Server

  1. #1
    Membre averti
    Homme Profil pro
    Sapeur pompier
    Inscrit en
    Février 2008
    Messages
    442
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Sapeur pompier
    Secteur : Service public

    Informations forums :
    Inscription : Février 2008
    Messages : 442
    Points : 416
    Points
    416
    Par défaut Faire un update avec resultat différent par rapport à l'ID
    Bonjour,

    Je souhaite mettre à jour la table commentaire et j'ai 303 lignes à mettre à jour.
    L'inconvénient c'est que je dois mettre à jour le commentaire par rapport au commentaire déjà existant. en gros il faut que j'enlève une partie du commentaire qui lors d'un copier/coller à écrit des lignes de codes.
    Pour trouver mes commentaires "incriminés" je passe par la requête suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    select 
    w.code,
    w.CREATEDATE,
    d.*
     from cswo_wo w
    inner join CSSY_DESCRIPTION d
    	on d.id = w.COMMENT
    where d.RAWDESCRIPTION like '<!%'
    Et pour mettre à jour le commentaire je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     update CSSY_DESCRIPTION
     set RAWDESCRIPTION = SUBSTRING(rawdescription,(charindex('endif] -->',rawdescription)+10),len(rawdescription)),
     DESCRIPTION = SUBSTRING(rawdescription,(charindex('endif] -->',rawdescription)+10),len(rawdescription))
     where id ='15da6051f82-9af1'
    Comment puis je faire pour que ça change le commentaire par rapport à chaque commentaires incriminés?
    Je pensais à cette requête mais c'est pas ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     update CSSY_DESCRIPTION
     set RAWDESCRIPTION = SUBSTRING(rawdescription,(charindex('endif] -->',rawdescription)+10),len(rawdescription)),
     DESCRIPTION = SUBSTRING(rawdescription,(charindex('endif] -->',rawdescription)+10),len(rawdescription))
     where id = (select 
    d.ID
     from cswo_wo w
    inner join CSSY_DESCRIPTION d
    	on d.id = w.COMMENT
    where d.RAWDESCRIPTION like '<!%')
    Pouvez-vous m'aider SVP.

    Merci par avance.

    Cordialement

    Sebing
    Débutant, j’essaie de m’améliorer en essayant d'aider sur le forum
    Merci d’être indulgent sur le code ou réponse proposé je reçois volontiers les critiques qui me feront progresser, mais aussi un (ça fait toujours plaisir de savoir que l on a pu dépanner une personne ).

  2. #2
    Membre averti
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2014
    Messages
    257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2014
    Messages : 257
    Points : 395
    Points
    395
    Par défaut
    Bonjour bonjour,

    Tout d'abord, pour votre requête d'update, peut-être mettre un "where id IN (select)" et non "where id=(select...)"

    Ensuite, j'ai peut-être mal lu mais dans votre requête update, vous faites appel à la table "cswo_wo" mais je n'ai pas vraiment l'impression qu'elle vous serve. Si c'est en effet le cas, vous n'avez donc besoin que de la table CSSY_DESCRIPTION qui est la table dans laquelle vous faites votre update. Ainsi, ne serait-il pas possible de limiter votre update à seulement une requête comme cela ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    update CSSY_DESCRIPTION
     set RAWDESCRIPTION = SUBSTRING(rawdescription,(charindex('endif] -->',rawdescription)+10),len(rawdescription)),
     DESCRIPTION = SUBSTRING(rawdescription,(charindex('endif] -->',rawdescription)+10),len(rawdescription))
     where RAWDESCRIPTION like '<!%'
    Bisous bisous

  3. #3
    Membre averti
    Homme Profil pro
    Sapeur pompier
    Inscrit en
    Février 2008
    Messages
    442
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Sapeur pompier
    Secteur : Service public

    Informations forums :
    Inscription : Février 2008
    Messages : 442
    Points : 416
    Points
    416
    Par défaut
    Merci d'avoir relevé mon erreur idiote
    Avec in ça fonctionne mieux.

    Merci encore.

    Bonne journée

    sebing
    Débutant, j’essaie de m’améliorer en essayant d'aider sur le forum
    Merci d’être indulgent sur le code ou réponse proposé je reçois volontiers les critiques qui me feront progresser, mais aussi un (ça fait toujours plaisir de savoir que l on a pu dépanner une personne ).

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

Discussions similaires

  1. Savoir le resultat suivant par rapport au resultat trouvé
    Par lonycc dans le forum Langage SQL
    Réponses: 3
    Dernier message: 14/09/2006, 18h26
  2. [ADO] faire une Update avec un recordset
    Par maniolo dans le forum VB 6 et antérieur
    Réponses: 12
    Dernier message: 21/08/2006, 22h18
  3. [VB] faire un update avec une bdd en xml
    Par ekmule dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 01/02/2006, 22h41
  4. Faire un update avec une ss requete renvoyant plusieur row
    Par djodjo dans le forum Langage SQL
    Réponses: 6
    Dernier message: 02/09/2005, 15h51
  5. [ SQL ] Faire un update avec un select imbriqué
    Par zozolh2 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 11/04/2005, 12h05

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