opdatere ændrede felter fra GridView
hejsaJeg ville gerne have registreret ÆNDRINGERNE i databasen fra et Datagridview.
Mit datagrid ser således ud:
<asp:GridView ID="GridProducts" runat="server" BorderWidth="1px" AutoGenerateColumns="False" AllowSorting="True" Width="505px" OnSorting="GridViewProducts_Sorting" OnRowDataBound="GridProducts_RowDataBound">
<HeaderStyle CssClass="DataGridHeader" />
<Columns>
<asp:BoundField DataField="ProductName" SortExpression="ProductNameSort" HeaderText="Produkt" />
<asp:BoundField DataField="VendorName" SortExpression="VendorNameSort" HeaderText="Leverandør" />
<asp:BoundField DataField="ProductFamilyName" SortExpression="ProductFamilyNameSort" HeaderText="Produktfamilie" NullDisplayText="N/A" />
<asp:BoundField DataField="ProductLine" HeaderText="Produktlinie" SortExpression="ProductLineSort" />
<asp:TemplateField HeaderText="Synlig">
<ItemTemplate>
<asp:CheckBox OnCheckedChanged="Checkchanged" ID="CheckBoxVisible" runat="server" />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
Det er når brugeren ændrer synligheds-bitten i CheckBoxen, at jeg ønsker at opdatere databasen. Databasen opdateres når jeg kender:
1) ProductID (står ikke i Datagriddet, men bliver bindet i Code-behind-filen.
2) Synlig/usynlig Checkboxen (synlig = checked)
Jeg har googlet mig frem til at jeg kan gennemløbe hele baduljen igennem og opdatere på den måde. I stil med(IKKE afprøvet):
foreach (GridViewRow row in GridProducts.Rows)
{
CheckBox cb = (CheckBox)row.FindControl("CheckBoxVisible");
if (cb != null && cb.)
{
bool visible = cb.Checked;
// få fat i produktid'et
int productID = Convert.ToInt32(GridProducts.DataKeys[row.RowIndex].Value);
}
}
Dette er IKKE en brugbar løsning, da jeg ikke ønsker at opdatere samtlige produkter men kun ønsker at opdatere de ÆNDREDE produkter.
Det nærmeste jeg er kommet en løsning er følgende:
public void Checkchanged(object sender, EventArgs e)
{
CheckBox box = (CheckBox)sender;
Page.Response.Write(box.Checked);
}
Her får jeg kun de ændrede checkboxe... meen jeg mangler det tilhørende ProductID
Håber I kan hjælpe