gpt4 book ai didi

c# - 通过循环检查列表框从数据库表中填充和删除项目

转载 作者:太空宇宙 更新时间:2023-11-03 16:47:49 24 4
gpt4 key购买 nike

我想做的是根据第一个选中列表框中的选定项目填充第二个选中列表框,并在第一个框中未选中父项时从数据库中删除这些项目。我可以通过仅遍历已选中 项目来填充第二个框,但是,如果我要从表中删除它们,我还需要包括未选中的项目。这是我目前的代码:

        for (int i = 0; i < ckbObjectives.Items.Count; i++)
{
objectiveTableAdapter.ClearBeforeFill = false;

if (ckbObjectives.GetItemChecked(i))
{
this.objectiveTableAdapter.FillByParentObjective((CWSToolkitDataSet.ObjectiveDataTable)cWSToolkitDataSet.Tables["ChildObjectives"], Convert.ToInt32(((DataRowView)ckbObjectives.Items[i])[ckbObjectives.ValueMember].ToString()));
}
else
{
this.objectiveTableAdapter.Delete((CWSToolkitDataSet.ObjectiveDataTable)cWSToolkitDataSet.Tables["ChildObjectives"], Convert.ToInt32(((DataRowView)ckbObjectives.Items[i])[ckbObjectives.ValueMember].ToString()));
}
}

cblSubObjectives.DataSource = cWSToolkitDataSet.Tables["ChildObjectives"];
cblSubObjectives.DisplayMember = "Title";
cblSubObjectives.ValueMember = "ObjectiveID";

我没有收到任何错误,但是第二个选中的列表框没有被填充。任何帮助将不胜感激。谢谢!

最佳答案

假设您检查的内容正确,这应该有效。

你能仔细检查你正在循环的 CheckedListBox 并确保你得到正确的响应吗:

for (int i = 0; i < ckbObjectives.Items.Count; i++)
{
MessageBox.Show(String.Format("{0}: {1}",
ckbObjectives.GetItemText(ckbObjectives.Items[i]),
ckbObjectives.GetItemCheckState(i).ToString()));
}

我仍然不确定您是否使用 WinForms/WebForms/WPF 等,但请将上面的 MessageBox.Show 替换为最适合输出的内容。这至少可以确保您查看的是正确的最新数据。

关于c# - 通过循环检查列表框从数据库表中填充和删除项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5275485/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com