2014-10-05 115 views
0

我有一個附件數據網格與數據庫源。 這些列是:查看|文件名|去掉。如何使用鏈接按鈕刪除數據

如何刪除鏈接按鈕單擊上的數據行?目前,數據行只能從數據網格中刪除,而不能從數據庫中刪除。

<dx:ASPxGridView ID="gvwAttachmentFileOld" runat="server" KeyFieldName="Id" Width="520px" OnLoad="gvwFileAttachmentOld_Load" OnRowCommand="gvwAttachmentFileOld_RowCommand1"> 
<Columns> 
    <dx:GridViewDataTextColumn ReadOnly="True" VisibleIndex="0" Caption="Action" Width="50px"> 
     <DataItemTemplate> 
      <asp:LinkButton ID="btnDownloadGridOld" runat="server" Text="View" OnClick="btnDownloadGridOld_Click"></asp:LinkButton> 
     </DataItemTemplate> 
    </dx:GridViewDataTextColumn> 
    <dx:GridViewDataTextColumn Caption="Id" FieldName="Id" Visible="false" VisibleIndex="1"></dx:GridViewDataTextColumn> 
    <dx:GridViewDataTextColumn Caption="File Name" FieldName="FileName" Width="450px"></dx:GridViewDataTextColumn> 
    <dx:GridViewDataTextColumn ReadOnly="True" VisibleIndex="4" Caption="Action" Width="50px"> 
     <DataItemTemplate> 
      <asp:LinkButton ID="btnHapusItemGridOld" runat="server" Text="Remove" CommandName="RemoveRow" CommandArgument='<%# DataBinder.Eval(Container, "DataItem.Id") %>'></asp:LinkButton> 
     </DataItemTemplate> 
    </dx:GridViewDataTextColumn>             
</Columns> 
</dx:ASPxGridView> 

protected void gvwAttachmentFileOld_RowCommand1(object sender,  DevExpress.Web.ASPxGridView.ASPxGridViewRowCommandEventArgs e) 
{ 
    if (e.CommandArgs.CommandName == "RemoveRow") 
    { 
    DataTable dtAttOld = (DataTable)Session["dtOld"]; 
    for (int i = 0; i < gvwAttachmentFileOld.VisibleRowCount; i++) 
    { 
     var id = e.CommandArgs.CommandArgument; 
     string idx = Convert.ToString(id); 

     DataRow[] dr = dtAttOld.Select(String.Format("Id = '{0}'", String.IsNullOrEmpty(idx) ? "0" : idx)); 

     if (dr != null) 
     { 
      dtAttOld.Rows.Remove(dr[0]); 
      dtAttOld.AcceptChanges(); 
     } 
    } 
    Session["dtOld"] = dtAttOld; 
    LoadGridAttachment(); 
    } 
} 
+0

你能提供'LoadGridAttachment'嗎? – Grundy 2014-10-05 07:59:10

回答

0

從datagridview刪除行不會影響數據庫中的數據表。您需要編寫查詢以從數據庫中刪除數據。

如果您使用的是sql,請嘗試類似於獲取鏈接按鈕事件上的主鍵或任何唯一列,然後實施命令以刪除該行。

這就像

鏈接按鈕點擊事件

int foo = int.Parse(yourDataGridView.SelectedRows[0].Cells[0].Value.ToString()); 

查詢刪除

delete from your table 
where pKey = foo;