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

ASP Discussion :

probleme update apres une boucle Do WHile Loop


Sujet :

ASP

  1. #1
    Membre régulier
    Inscrit en
    Juin 2005
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 150
    Points : 93
    Points
    93
    Par défaut probleme update apres une boucle Do WHile Loop
    Bonjour,

    je parcours un recordset afin de generer un tableau, avec une boucle do while loop.

    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
     
    DO WHILE ObjtmpP3.EOF = FALSE
     
    .Write ("<tr >")					
        .Write ("<td>" & idlign & "</td>")
        .Write ("<td>" & ObjtmpP3("id")& "</td>")
        .Write ("<td ><img src='" & ObjtmpP3("Icon") & "'>&nbsp;" & ObjtmpP3("Title") & "</td>")
         .Write ("<td>" & ObjtmpP3("PosProcess") & "</td>")
         .Write ("<td><input type='radio' value='" & ObjtmpP3("posprocess")&"' name='change' >")
         .Write ("</td>")
    .Write("</tr>")
     
    ObjtmpP3.Movenext
    idlign = idlign + 1 
    LOOP
     
     
    changeValuePos = Request("change")
    newpos = changeValuePos + 1
    pour l'instant pas de soucis.

    le probleme vient a partir du moment ou je veux faire un update pour mettre a jour une ligne, je bloque sur la partie "WHere"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    sqlUp = " Update TreeV_hierarchy Set [posprocess] = " & newpos & "WHERE idprocess=" & ObjtmpP3("id")
    je n'arrive pas a recuperer l'id d'une ligne. Quand j'utilise cette requete, j'obtiens une erreur d'exception.
    je sais bien que c le " objtempP3("id") qui pose probleme parce qu'il n'est pas clairement defini , mais voila je ne sais pas comment faire ...

    si vous aviez des pistes pour m'eclairer

    merci d'avance

  2. #2
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 506
    Points
    9 506
    Par défaut
    Salut,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sqlUp = "Update TreeV_hierarchy Set [posprocess] = " & newpos & " WHERE idprocess= " & request.form("change")
    :
    De plus, il manquait un espace avant WHERE.
    A+
    "Winter is coming" (ma nouvelle page d'accueil)

  3. #3
    Membre régulier
    Inscrit en
    Juin 2005
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 150
    Points : 93
    Points
    93
    Par défaut
    Salut,

    Merci pour ta reponse.

    en fait le soucis c que je recupere deja le " request.form("change") dans une variable " newpos" incremente de 1 .

    est il possible de recuperer l' ID de chaque ligne ( objtempP3("id") ), et de faire un update en fonction d'un ID particulier ?

    merci pour l'aide

  4. #4
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 506
    Points
    9 506
    Par défaut
    Peux-tu mettre ta ligne de mise à jour à sa place dans le code que je vois ça de plus près?
    Merci
    "Winter is coming" (ma nouvelle page d'accueil)

  5. #5
    Membre régulier
    Inscrit en
    Juin 2005
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 150
    Points : 93
    Points
    93
    Par défaut
    bonjour,

    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
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
     
    QueryParent = "SELECT Title, posprocess,icon,id FROM TreeV_processes"
    TempSqlParent3 = QueryParent & " WHERE parent = "& 1 & " ORDER BY posprocess"
     
    Set ObjtmpP3 = Server.CreateObject("ADODB.RECORDSET")
    Set ObjtmpP3 = Cxn.Execute(tempSqlParent3)
     
    IF ObjtmpP3.EOF = TRUE THEN
     
          .Write("<br><br>")
          .Write ("<b><i> No Child Element for this title in the database </i></b>")
     
    ELSE
     
        .Write("<form method='post'>")
        .Write("<table border='01' cellspading='0' cellspacing='0' align='center' valign='center'>")
     
       .Write("<tr>")
     
       .Write("<th> id lign </th>")			
       .Write("<th> Id </th>")                      
       .Write("<th>Title</th>")
       .Write("<th>Position</th>")
       .Write("<th></th>")
     
       .Write("</tr>")
     
     
        idlign = 1
     
        DO WHILE ObjtmpP3.EOF = FALSE
     
        .Write ("<tr >")
        .Write ("<td>" & idlign & "</td>")
        .Write("<td>" & ObjtmpP3("id")& "</td>")
        .Write("<td ><img src='" & ObjtmpP3("Icon") & "'>&nbsp;" & ObjtmpP3("Title") & "</td>")
        .Write("<td>" & ObjtmpP3("PosProcess") & "</td>")
        .Write("<td><input type='radio' value='" & ObjtmpP3("posprocess")&"' name='change' id ='" & ObjtmpP3("id")& "' >")
        .Write("</td>")
        .Write("</tr>")
     
       ObjtmpP3.Movenext
        idlign = idlign + 1 
     
        LOOP
     
                     .Write("</table>")
                     .Write("<input type='submit' name='sendup'> &nbsp; <input type='submit' name='senddown'>")
                     .Write("</form>")
     
         IF request("sendup") <> "" then
    							IF Request("change")<>"" THEN
     
                              changeValuePos = Request("change")  
                                           newpos = changeValuePos + 1
     
                     sqlUp = " Update TreeV_hierarchy Set [posprocess] = " & newpos '& " WHERE id=" & ObjtmpP3("id") 
     
                        END IF 
     
         END IF 
     
    END IF
    voila le code.

    En fait en selectionnant un bouton radio et en cliquant sur le bouton ("sendUp"), je recupere la valeur de ce bouton radio, je lui rajoute 1 et je mets a jour la base avec cette nouvelle valeur, seulement si je ne precise pas quel enregistrement je veux mettre a jour, ca va me mettre la meme valeur pour toute la colonne...

    seulement je n'arrive pas a recuperer l'ID de l'element que je veux mettre a jour...

    merci encore d'avance pour votre aide

  6. #6
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 506
    Points
    9 506
    Par défaut
    Ben tu affectes simplement la valeur de ton ID à ton bouton radio.
    "Winter is coming" (ma nouvelle page d'accueil)

  7. #7
    Membre régulier
    Inscrit en
    Juin 2005
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 150
    Points : 93
    Points
    93
    Par défaut
    salut,

    merci pour ta reponse.

    le petit probleme est que je dois recuperer l'ID d'un element MAIS AUSSI la position de ce dernier. si je change la valeur actuelle du bouton par celle de l'ID , je vais pour recuperer l'ID mais ne pourrais plus avoir sa position parce que a chaque fois que je fais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     .write ObjtmpP3("PosProcess")
    il me met toutes les positions et pas celle en rapport avec le bouton radio

    mais peut etre que c simple et que je me complique la vie, je sais plus trop la je m'embrouille un peu ....

  8. #8
    Membre régulier
    Inscrit en
    Juin 2005
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 150
    Points : 93
    Points
    93
    Par défaut
    re,

    bon ben j'ai trouver une solution a mon probleme, je ne sais pas si c la plus efficace, mais ca a l'air de marcher.

    avant de faire mon update, je fais une nouvelle requete ( un select ) pour recuperer la position en fonction du bouton clique, a laquelle je rajoute 1.
    Je recupere cette nouvelle valeur dans une variable que j'utilise apres dans mon update .

    je coche " resolu " mais si quelqu'un voit une methode plus simple, je suis partant .

    merci encore immobilis pour ton aide

  9. #9
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 506
    Points
    9 506
    Par défaut
    A quoi cela te sert de récupérer la position?
    "Winter is coming" (ma nouvelle page d'accueil)

  10. #10
    Membre régulier
    Inscrit en
    Juin 2005
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 150
    Points : 93
    Points
    93
    Par défaut
    En fait ,

    c'est cette donnee que je veux mettre a jour.

    toutes ces donnees, font partie d'un menu hierarchique, et la page que je dois mettre en place doit permettre a un utilisateur de changer la position de chaque elements dans ce menu. c 'est pour cela que je dois "jouer" avec les positions.

    dans ce tableau, sont listes tous les elements enfants trier par position.
    Donc en selectionnant un element avec le bouton radio et un bouton submit, l'utilisateur doit pouvoir descendre ou monter l'element d'une position.

    je ne sais pas s'il existe une facon plus appropriee ou plus efficace pour le faire... celle la pour l'instant a l'air de marcher, donc...

  11. #11
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 506
    Points
    9 506
    Par défaut
    Ben dans la valeur du bouton radio tu mets les deux "ID-Position".
    Pour le traitement, tu fais un split
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Arr_IDPos = split(request.form("ID-Position"))
    Ou bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    left(request.form("ID-Position"),instr(request.form("ID-Position"),"-")-1)
    Un truc du genre.
    "Winter is coming" (ma nouvelle page d'accueil)

  12. #12
    Membre régulier
    Inscrit en
    Juin 2005
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 150
    Points : 93
    Points
    93
    Par défaut
    re,

    merci pour ton aide !! c vrai que c beaucoup mieux avec l'array et la fonction split

    merci encore !

  13. #13
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 506
    Points
    9 506
    Par défaut
    J'ai fait une petite erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Arr_IDPos = split(request.form("ID-Position"),"-")
    A+
    "Winter is coming" (ma nouvelle page d'accueil)

  14. #14
    Membre régulier
    Inscrit en
    Juin 2005
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 150
    Points : 93
    Points
    93
    Par défaut
    t'inquietes, j'avais pas vu l'erreur. comme je connaissais la fonction split j'ai repris ce que j'avais deja fait...

    merci encore

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

Discussions similaires

  1. Probleme dans une boucle do while
    Par serna dans le forum Langage
    Réponses: 5
    Dernier message: 03/06/2015, 16h27
  2. [AC-2003] Souci avec une boucle Do While à Loop
    Par Plume27 dans le forum VBA Access
    Réponses: 9
    Dernier message: 23/08/2012, 16h59
  3. probleme dans une boucle do while
    Par oldscrout dans le forum Débuter
    Réponses: 2
    Dernier message: 30/12/2008, 17h02
  4. Réponses: 2
    Dernier message: 06/02/2007, 15h05
  5. probleme de recordset dans une boucle do while
    Par Shoryu dans le forum ASP
    Réponses: 18
    Dernier message: 05/07/2004, 15h30

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