2013-11-15 64 views
0

我創建了一個DetailsView,它顯示基於GridView中選定項目的數據。當DetailsView處於編輯模式下時,它將顯示包含來自SQL數據綁定的數據的下拉列表。數據顯示在下拉列表中,沒有問題,但無法更新。其他所有領域都成功。asp.net c#DetailsView DropDownList無法更新

數據通過OnDataBound綁定到下拉菜單。 這個想法是用當前數據填充SelectedValue,並填充它可以更改的內容。這工作沒有問題。它只是無法更新。

我相信它與同步控件與「an」參數有關,但在如何做到這一點方面是一種損失。

前端代碼有關的問題:

<asp:DetailsView ID="userDetails" runat="server" 
      Height="50px" 
      Width="400px" 
      AutoGenerateRows="False" 
      CellPadding="4" 
      DataKeyNames="id" 
      DataSourceID="detailsSqlDataSource" 
      ForeColor="#333333" 
      GridLines="None" 
      OnDataBound="userDetails_ItemEdit"> 
      <AlternatingRowStyle BackColor="White" /> 
      <CommandRowStyle BackColor="#D1DDF1" Font-Bold="True" /> 
      <EditRowStyle BackColor="#2461BF" /> 
      <FieldHeaderStyle BackColor="#DEE8F5" Font-Bold="True" width="125px"/> 
      <Fields> 
       <asp:BoundField DataField="id" HeaderText="id" InsertVisible="False" ReadOnly="True" SortExpression="id" /> 
       <asp:BoundField DataField="first_name" HeaderText="First Name" SortExpression="first_name" /> 
       <asp:BoundField DataField="last_name" HeaderText="Last Name" SortExpression="last_name" /> 
       <asp:BoundField DataField="user_name" HeaderText="User Name" SortExpression="user_name" /> 
       <asp:TemplateField HeaderText="T" SortExpression="t"> 
        <EditItemTemplate> 
         <asp:DropDownList ID="tEditDD" runat="server" SelectedValue='<%# Bind("t") %>'> 
          <asp:ListItem Value="t1" Text="t1"></asp:ListItem> 
          <asp:ListItem Value="t2" Text="t2"></asp:ListItem> 
          <asp:ListItem Value="t3" Text="t3"></asp:ListItem> 
         </asp:DropDownList> 
        </EditItemTemplate> 
        <InsertItemTemplate> 
         <asp:TextBox ID="TextBox1" runat="server" Text='<%# Bind("t") %>'></asp:TextBox> 
        </InsertItemTemplate> 
        <ItemTemplate> 
         <asp:Label ID="Label1" runat="server" Text='<%# Bind("t") %>'></asp:Label> 
        </ItemTemplate> 
       </asp:TemplateField> 
       <asp:TemplateField HeaderText="P" SortExpression="p"> 
        <EditItemTemplate> 
         <asp:DropDownList ID="pEditDD" runat="server" SelectedValue='<%# Bind("p") %>'> 
          <asp:ListItem Value="As" Text="As"></asp:ListItem> 
          <asp:ListItem Value="An" Text="An"></asp:ListItem> 
          <asp:ListItem Value="Su" Text="Su"></asp:ListItem> 
          <asp:ListItem Value="Ad" Text="Ad"></asp:ListItem> 
         </asp:DropDownList> 
        </EditItemTemplate> 
        <InsertItemTemplate> 
         <asp:TextBox ID="TextBox2" runat="server" Text='<%# Bind("p") %>'></asp:TextBox> 
        </InsertItemTemplate> 
        <ItemTemplate> 
         <asp:Label ID="Label2" runat="server" Text='<%# Bind("p") %>'></asp:Label> 
        </ItemTemplate> 
       </asp:TemplateField> 
       <asp:TemplateField HeaderText="An" SortExpression="an"> 
        <EditItemTemplate> 
         <asp:DropDownList ID="anEditDD" runat="server"> 
         </asp:DropDownList> 
        </EditItemTemplate> 
        <InsertItemTemplate> 
         <asp:TextBox ID="TextBox3" runat="server" Text='<%# Bind("an") %>'></asp:TextBox> 
        </InsertItemTemplate> 
        <ItemTemplate> 
         <asp:Label ID="Label3" runat="server" Text='<%# Bind("an") %>'></asp:Label> 
        </ItemTemplate> 
       </asp:TemplateField> 
       <asp:TemplateField HeaderText="Su" SortExpression="su"> 
        <EditItemTemplate> 
         <asp:DropDownList ID="suEditDD" runat="server" > 
         </asp:DropDownList> 
        </EditItemTemplate> 
        <InsertItemTemplate> 
         <asp:TextBox ID="TextBox4" runat="server" Text='<%# Bind("su") %>'></asp:TextBox> 
        </InsertItemTemplate> 
        <ItemTemplate> 
         <asp:Label ID="Label4" runat="server" Text='<%# Bind("su") %>'></asp:Label> 
        </ItemTemplate> 
       </asp:TemplateField> 
       <asp:BoundField DataField="email" HeaderText="E-Mail" SortExpression="email" /> 
       <asp:TemplateField HeaderText="AL" SortExpression="al"> 
        <EditItemTemplate> 
         <asp:DropDownList ID="alEditDD" runat="server" SelectedValue='<%# Bind("al") %>'> 
          <asp:ListItem Value="As" Text="As"></asp:ListItem> 
          <asp:ListItem Value="An" Text="An"></asp:ListItem> 
          <asp:ListItem Value="Su" Text="Su"></asp:ListItem> 
          <asp:ListItem Value="Ad" Text="Ad"></asp:ListItem> 
         </asp:DropDownList> 
        </EditItemTemplate> 
        <InsertItemTemplate> 
         <asp:DropDownList ID="alInsertDD" runat="server" SelectedValue='<%# Bind("al") %>'> 
          <asp:ListItem></asp:ListItem> 
          <asp:ListItem Value="As" Text="As"></asp:ListItem> 
          <asp:ListItem Value="An" Text="An"></asp:ListItem> 
          <asp:ListItem Value="Su" Text="Su"></asp:ListItem> 
          <asp:ListItem Value="Ad" Text="Ad"></asp:ListItem> 
         </asp:DropDownList> 
        </InsertItemTemplate> 
        <ItemTemplate> 
         <asp:Label ID="Label5" runat="server" Text='<%# Bind("al") %>'></asp:Label> 
        </ItemTemplate> 
       </asp:TemplateField> 
       <asp:CommandField ShowDeleteButton="True" ShowEditButton="True" ShowInsertButton="True" /> 
      </Fields> 
      <FooterStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" /> 
      <HeaderStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" /> 
      <PagerStyle BackColor="#2461BF" ForeColor="White" HorizontalAlign="Center" /> 
      <RowStyle BackColor="#EFF3FB" /> 
     </asp:DetailsView> 
     <asp:SqlDataSource ID="detailsSqlDataSource" runat="server" 
      ConflictDetection="CompareAllValues" 
      ConnectionString="<%$ ConnectionStrings:CPConnectionString %>" 

      UpdateCommand="UPDATE [users] SET [first_name] = @first_name, [last_name] = @last_name, [user_name] = @user_name, [t] = @t, [p] = @p, [an] = @an, [su] = @su, [email] = @email, [al] = @al WHERE [id] = @original_id"> 

      <SelectParameters> 
       <asp:ControlParameter ControlID="usersGrid" Name="id" PropertyName="SelectedValue" Type="Int32" /> 
      </SelectParameters> 
      <UpdateParameters> 
       <asp:Parameter Name="first_name" Type="String" /> 
       <asp:Parameter Name="last_name" Type="String" /> 
       <asp:Parameter Name="user_name" Type="String" /> 
       <asp:Parameter Name="t" Type="String" /> 
       <asp:Parameter Name="p" Type="String" /> 
       <asp:Parameter Name="an" Type="String" /> 
       <asp:Parameter Name="su" Type="String" /> 
       <asp:Parameter Name="email" Type="String" /> 
       <asp:Parameter Name="al" Type="String" /> 
       <asp:Parameter Name="original_id" Type="Int32" /> 
       <asp:Parameter Name="original_first_name" Type="String" /> 
       <asp:Parameter Name="original_last_name" Type="String" /> 
       <asp:Parameter Name="original_user_name" Type="String" /> 
       <asp:Parameter Name="original_t" Type="String" /> 
       <asp:Parameter Name="original_p" Type="String" /> 
       <asp:Parameter Name="original_an" Type="String" /> 
       <asp:Parameter Name="original_su" Type="String" /> 
       <asp:Parameter Name="original_email" Type="String" /> 
       <asp:Parameter Name="original_al" Type="String" /> 
      </UpdateParameters> 
     </asp:SqlDataSource> 

代碼背後:

protected void userDetails_ItemEdit(object sender, EventArgs e) 
{ 
    if (userDetails.CurrentMode == DetailsViewMode.Edit) 
    { 
     AnDD(); 
    } 
} 

protected void AnDD() 
{ 
    DropDownList anEditDD = userDetails.FindControl("anEditDD") as DropDownList; 
    string userName = ((TextBox)userDetails.Rows[3].Cells[1].Controls[0]).Text; 
    string conStr = System.Configuration.ConfigurationManager.ConnectionStrings["CPConnectionString"].ConnectionString; 
    SqlConnection con = new SqlConnection(conStr); 
    con.Open(); 

    string currentAnSqlSelect = "SELECT an FROM users WHERE user_name='" + userName + "'"; 
    SqlDataReader currentReader; 
    SqlCommand ccmd = new SqlCommand(currentAnSqlSelect, con); 
    currentReader = ccmd.ExecuteReader(); 
    while (currentReader.Read()) 
    { 
     ListItem currentList = new ListItem(); 
     currentList.Text = currentReader["an"].ToString(); 
     errorLBL.Text = currentReader["an"].ToString(); 
     anEditDD.Items.Add(currentList); 
    } 
    currentReader.Close(); 

    string anSqlSelect = "SELECT first_name, last_name FROM users WHERE position='An'"; 
    SqlDataReader anReader; 

    SqlCommand cmd = new SqlCommand(anSqlSelect, con); 
    anReader = cmd.ExecuteReader(); 
    while (anReader.Read()) 
    { 
     ListItem anList = new ListItem(); 
     anList.Text = anReader["first_name"].ToString() + " " + anReader["last_name"].ToString(); 
     anEditDD.Items.Add(anList); 
    } 
    anReader.Close(); 
    con.Close(); 
    anEditDD.Items.Add("N/A"); 
    anEditDD.DataBind(); 
    anEditDD.SelectedIndex = 0; 
} 
+0

當你說「它沒有更新」,這是否意味着在試圖挽救它實際上生成SQL的錯誤信息,或者它只是不救?如果它產生一個錯誤,那麼錯誤是什麼?如果它只是不更新​​,查看SQL事件探查器並查看發送到服務器的更新語句是什麼。 –

+0

無法保存。因爲我沒有使用SelectedValue ='<%#Bind(「an」)%>'語句,所以我不相信這個值在SQL中被傳遞和更新。嘗試使用上述語句和OnDataBound時出現錯誤。 – hollow

回答

0

你update命令似乎是細節部分來看,而不是任何ObjectDataSource控件的一部分。你能確認你的標記是否正確?

編輯

在你UpdateParameters組,你是不是從控制得到的值。請嘗試執行以下操作:

<UpdateParameters> 
    <asp:Parameter /> 
    ...snip 
    <asp:ControlParameter Name="an" ControlID="idOfWhateverControlHasTheUserSetValue" Type="String" /> 
    ...snip 
</UpdateParameters> 
+0

這是來自asp:SqlDataSource的DetailsView – hollow

+1

是的,但它在你的DetailsView標記的中間混合。如果您清理了上面的標記以儘可能近似地類似您現有的代碼,那將會非常有幫助。你可以使用'snip'類型的提示來指出你遺漏了哪些部分不會影響問題。 –

+0

編輯協助 – hollow

0

我接受了您的建議,並對使用ControlParameter做了一些調查。

該修復程序將以下內容添加到更新參數中,並刪除'an'的自動填充參數。感謝您的幫助,Nick。

<asp:ControlParameter Name="an" ControlID="userDetails$anEditDD" PropertyName="SelectedValue" Type="String" />