вложенный gridview нет данных, если родительский gridview заполнен (где = querystring) нужна помощь здесь - PullRequest
1 голос
/ 21 декабря 2011

вопрос как выше.У меня есть родительский gridview, который будет заполнен, принимая строку запроса.однако дочерний gridview (вложенный) не будет заполнен.я тоже не понимаю почему.любая помощь?

 <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
         BorderColor="Black" BorderStyle="Solid" DataKeyNames="QuestionID" 
         DataSourceID="SqlDataSource1" Width="447px">
         <Columns>
             <asp:BoundField DataField="QuestionID" HeaderText="QuestionID" ReadOnly="True" 
                 SortExpression="QuestionID" />
             <asp:BoundField DataField="SurveyID" HeaderText="SurveyID" 
                 SortExpression="SurveyID" />
             <asp:BoundField DataField="QuestionTitle" HeaderText="QuestionTitle" 
                 SortExpression="QuestionTitle" />
             <asp:BoundField DataField="AnswerType" HeaderText="AnswerType" 
                 SortExpression="AnswerType" />
             <asp:TemplateField>
                 <ItemTemplate>
                     <asp:GridView ID="GridView2" runat="server" AutoGenerateColumns="False" 
                         BorderStyle="Solid" DataSourceID="SqlDataSource2">
                         <Columns>
                             <asp:BoundField DataField="AnswerValue" HeaderText="AnswerValue" 
                                 SortExpression="AnswerValue" />
                         </Columns>
                     </asp:GridView>
                 </ItemTemplate>
             </asp:TemplateField>
         </Columns>
     </asp:GridView>
     <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
         ConnectionString="<%$ ConnectionStrings:myConnectionString %>" 
         SelectCommand="SELECT * FROM [Question] WHERE ([SurveyID] = @SurveyID)">
         <SelectParameters>
             <asp:QueryStringParameter Name="SurveyID" QueryStringField="sid" 
                 Type="String" />
         </SelectParameters>
     </asp:SqlDataSource>

  </div>

            <asp:SqlDataSource ID="SqlDataSource2" runat="server" 
                ConnectionString="<%$ ConnectionStrings:myConnectionString %>" 


     SelectCommand="SELECT AnswerValue FROM Results WHERE (QuestionID = @QuestionID)">
                <SelectParameters>
                    <asp:Parameter Name="QuestionID" />
                </SelectParameters>
            </asp:SqlDataSource>

1 Ответ

0 голосов
/ 21 декабря 2011

Вы можете добавить HiddenField в ItemTemplate GridView1 и связать его с QuestionID.

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
   ...
     <asp:TemplateField>
        <ItemTemplate>
         <asp:HiddenField ID="HiddenField1" runat="server" 
                            Value='<%# Eval("QuestionID") %>' />
          <asp:GridView ID="GridView2" runat="server" AutoGenerateColumns="False" 
                BorderStyle="Solid" DataSourceID="SqlDataSource2">
                <Columns>
                  <asp:BoundField DataField="AnswerValue" HeaderText="AnswerValue" 
                   SortExpression="AnswerValue" />
                </Columns>
           </asp:GridView>
        </ItemTemplate>
     </asp:TemplateField>
   </Columns>
</asp:GridView>

и использовать ControlParameter для сравнения QuestionID с SqlDataSource2.

<asp:SqlDataSource ID="SqlDataSource2" runat="server" 
                ConnectionString="<%$ ConnectionStrings:myConnectionString %>" 
     SelectCommand="SELECT AnswerValue FROM Results WHERE (QuestionID = @QuestionID)">
     <SelectParameters>
      <asp:ControlParameter ControlID="HiddenField1" Name="QuestionID" 
                                    PropertyName="Value" Type="Int32" />
     </SelectParameters>
</asp:SqlDataSource>
...