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.NET Discussion :

UpdatePanel et base de données (.Net C# Visual Sutdio 2005)


Sujet :

ASP.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    228
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 228
    Par défaut UpdatePanel et base de données (.Net C# Visual Sutdio 2005)
    Bonjour,

    Voulant faire un update panel, je me suis fait une page test.

    Dedans, j'ai un ScriptManager, un UpdatePanel qui lui contient un Timer, un label (heure), un SQLDataSource et un Repeater.

    Je fais une requête pour chercher un nombre aléatoire dans ma base, et je l'affiche dans le repeater.

    L'updatePanel fonctionne (l'heure change bien) mais ma requête n'est pas éxécutée à nouveau. Le nom ne change donc pas ...

    J'utilise Visual Sutdio 2005. C#

    Pourriez-vous m'aider ?

    Merci d'avance
    Scots

  2. #2
    Membre Expert
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Par défaut
    Pourrais-tu nous donner ton code que l'on puisse voir ce qui ne fonctionne pas ?

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    228
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 228
    Par défaut
    Voici mon code de test. Bien entendu la requête fonctionne. Mon seul problème est de la relancer au "refresh" de k'updatepanel.

    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
    <html dir="ltr" xmlns="http://www.w3.org/1999/xhtml">
    <head id="Head1" runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Untitled 1</title>
    <script runat="server" type="text/c#">
        protected void TTest_Tick(object sender, EventArgs e)
        {
            LbText.Text = "Panel refreshed at: " + DateTime.Now.ToLongTimeString();
            SqlDataSource1.SelectCommand = "SELECT nom FROM tb_personnage ORDER BY RAND() LIMIT 1";
            SqlDataSource1.DataBind();
        }
    </script>
    </head>
    <body>
    <form id="form1" runat="server">
    <asp:ScriptManager runat="server" id="SmTest" />
    <asp:UpdatePanel runat="server" id="UpTest">
        <ContentTemplate>
            <asp:Timer runat="server" id="TTest" Interval="5000" OnTick="TTest_Tick" />
            <asp:Label runat="server" Text="Page not refreshed yet." id="LbText" Width="150px" /><br /><br />
            <asp:Repeater ID="Repeater1" runat="server" DataSourceID="SqlDataSource1">
                <ItemTemplate>
                    <asp:Label runat="server" id="LbNom" Text='<%# Eval("Nom") %>' />
                </ItemTemplate>
            </asp:Repeater>
        </ContentTemplate>
        <Triggers>
            <asp:AsyncPostBackTrigger ControlID="Repeater1" EventName="ItemDataBound" />
        </Triggers>
    </asp:UpdatePanel>
     
    <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:medCS %>" ProviderName="<%$ ConnectionStrings:medCS.ProviderName %>" SelectCommand="SELECT nom FROM tb_personnage ORDER BY RAND() LIMIT 1" />
    <asp:Label runat="server" Text="Le texte de la ligne du dessus devrait changer" id="Label2" />
    </form>
    </body>
    </html>

  4. #4
    Membre Expert
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Par défaut
    Je ne gère pas mes updatepanel ainsi mais plutôt de la manière suivante :

    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <asp:Timer ID="listeAlarmesRefresh" OnTick="ListeAlarmesRefresh_Tick" runat="server">
       </asp:Timer>
    <asp:UpdatePanel ID="panelList" runat="server" UpdateMode="Conditional">
          <Triggers>
             <asp:AsyncPostBackTrigger ControlID="listeAlarmesRefresh" EventName="Tick" />
          </Triggers>
          <ContentTemplate>
    #MON_CONTENU#
    </ContentTemplate>
       </asp:UpdatePanel>

    Après le Tick, j'ai bien mes données à jour. Peux-tu essayer ainsi ?

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    228
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 228
    Par défaut
    Test effectué : Idem, la requête n'est pas relancée.

    Code modifié :
    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
    <form id="form1" runat="server">
    <asp:ScriptManager runat="server" id="SmTest" />
    <asp:Timer runat="server" id="TTest" Interval="5000" OnTick="TTest_Tick" />
    <asp:UpdatePanel runat="server" id="UpTest">
        <Triggers>
            <asp:AsyncPostBackTrigger ControlID="Repeater1" EventName="ItemDataBound" />
        </Triggers>
        <ContentTemplate>
            <asp:Label runat="server" Text="Page not refreshed yet." id="LbText" Width="150px" /><br /><br />
            <asp:Repeater ID="Repeater1" runat="server" DataSourceID="SqlDataSource1">
                <ItemTemplate>
                    <asp:Label runat="server" id="LbNom" Text='<%# Eval("Nom") %>' />
                </ItemTemplate>
            </asp:Repeater>
        </ContentTemplate>
    </asp:UpdatePanel>
     
    <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:medCS %>" ProviderName="<%$ ConnectionStrings:medCS.ProviderName %>" SelectCommand="SELECT nom FROM tb_personnage ORDER BY RAND() LIMIT 1" />
    <asp:Label runat="server" Text="Le texte de la ligne du dessus devrait changer" id="Label2" />
    </form>
    J'avais oublié de corriger le Timer. Fait mais idem :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <Triggers>
            <asp:AsyncPostBackTrigger ControlID="TTest" EventName="Tick" />
        </Triggers>

  6. #6
    Membre Expert
    Avatar de jbrasselet
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Mars 2006
    Messages
    1 022
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 022
    Par défaut
    Et si tu fais un ?

  7. #7
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Citation Envoyé par Scots Voir le message
    Voici mon code de test. Bien entendu la requête fonctionne. Mon seul problème est de la relancer au "refresh" de k'updatepanel.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
        <Triggers>
            <asp:AsyncPostBackTrigger ControlID="Repeater1" EventName="ItemDataBound" />
        </Triggers>
    </asp:UpdatePanel>
    Faut pas oublier que le déclencheur devrait être de côté client mais non pas de côté serveur. ItemDataBound est un événement serveur et par conséquent il ne peut pas participer au refresh de l'UpdatePanel

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

Discussions similaires

  1. gérer base de donnée xml sous visual studio?
    Par _haroun dans le forum ASP.NET
    Réponses: 1
    Dernier message: 20/05/2010, 00h06
  2. Base de données integrée en Visual Basic 2008
    Par yidboulmane dans le forum Accès aux données
    Réponses: 8
    Dernier message: 19/03/2009, 18h34
  3. comment coupler une base de donnée access avec visual basic
    Par célom dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 22/10/2008, 17h08
  4. base de données .net
    Par ailedoiseau dans le forum VB.NET
    Réponses: 3
    Dernier message: 23/12/2007, 19h49
  5. Accès Réseau a une base de données Access par Visual Basic
    Par thegreatbato dans le forum VBA Access
    Réponses: 5
    Dernier message: 06/01/2006, 14h04

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