目前我有一个按钮单击事件,它从数据网格中的一行中获取数据键(通过复选框)并将其分配给一个 INT 变量以更新数据库中的个人。当我只选中 1 个复选框并运行更新时,一切正常。但是我需要用户可以选择所有复选框并获取所有这些数据键并将其分配给同一个变量
INT oNewParentID
就像我说的,当只有 1 个复选框被选中时,一切都可以正常工作。我想我在问如何获取未知数量的 Datakeys 或所有 Checkboxes 选择的所有 DataKeys 并将它们存储在上面的变量中,以便为所有选定的个人运行更新。到目前为止,这是我的按钮单击事件,它适用于选中的 1 个复选框:
protected void imgbtnReassgin_Click(object sender, ImageClickEventArgs e)
{
foreach (GridViewRow row in gvSalesmanCustomers.Rows)
{
CheckBox cb = (CheckBox)row.FindControl("chkSalesCustSelector");
if (cb != null && cb.Checked)
{
int oIndividualID = Convert.ToInt32((gvSalesmanCustomers.DataKeys[row.RowIndex].Value));
foreach (GridViewRow r in gvSalesmanByManager.Rows)
{
CheckBox chkBox = (CheckBox)r.FindControl("chkManagerSalesSelector");
if (chkBox != null && chkBox.Checked)
{
int oNewParentID = Convert.ToInt32((gvSalesmanByManager.DataKeys[r.RowIndex].Value));
Individual ind = new Individual();
ind.ReassignIndividual(oIndividualID, oNewParentID);
chkBox.Checked = false;
cb.Checked = false;
}
}
}
}
}
她是我的更新存储过程:
CREATE DEFINER=`root`@`%` PROCEDURE `reassign_Individual`(
IN oIndividualID int(11),
IN oNewParentID int(11)
)
BEGIN
Update intelliair.individual
set ParentID = oNewParentID
Where IndividualID = oIndividualID;END