C#中checkedlistbox的用法
我有两个checkedlistbox,其中的选择项分别从表1和表2中读出字段值f1、f2得到,现在我相每次从box1和box2中选一项或多项,然后把值填充到表3中,填充时...
我有两个checkedlistbox,其中的选择项分别从表1和表2中读出字段值f1、f2得到,现在我相每次从box1和box2中选一项或多项,然后把值填充到表3中,填充时,不仅只是f1和f2,还有表2中f2字段值对应的一行的其它字段,请问如何实现?
表1
f1值:a1 a2 a3
表2
f2 f3 f4
b1 c1 d1
b2 c2 d2
b3 c3 d3
box1中显示a1 a2 a3
box2中显示b1 b2 b3
当选中a1、a2和b1、b3时,向表3中写入内容为:
a1 b1 c1 d1
a1 b3 c3 d3
a2 b1 c1 d1
a2 b3 c3 d3
表3结构已建立:f1,f2,f3,f4 展开
表1
f1值:a1 a2 a3
表2
f2 f3 f4
b1 c1 d1
b2 c2 d2
b3 c3 d3
box1中显示a1 a2 a3
box2中显示b1 b2 b3
当选中a1、a2和b1、b3时,向表3中写入内容为:
a1 b1 c1 d1
a1 b3 c3 d3
a2 b1 c1 d1
a2 b3 c3 d3
表3结构已建立:f1,f2,f3,f4 展开
1个回答
展开全部
不知道你的表示listview还是dategridview
这个逻辑不难理解吧
循环获取box1中的选择项,对每项循环 添加 box2的选择内容
(当然是根据box2的选择值查询表2得到的详细值)
然后每次获得一行完整的表3项,就添加到表3
下面以listview 为例
listView3.Items.Clear();
for (int i = 0; i < checkedListBox1.CheckedItems.Count; i++)
{//获得表1的选择值
for (int j = 0; j < checkedListBox2.CheckedItems.Count; j++)
{//获得表2的选择值
//新的表3的行
ListViewItem lvi = new ListViewItem();
lvi.Text = checkedListBox1.CheckedItems[i].ToString();
for (int k = 0; k < listView2.Items.Count; k++)
{//获得完整的表2 的值,并添加到ListViewItem
if (listView2.Items[k].Text == lvi.Text)
{
lvi.SubItems.Add(listView2.Items[k].SubItems[0].Text);
lvi.SubItems.Add(listView2.Items[k].SubItems[1].Text);
lvi.SubItems.Add(listView2.Items[k].SubItems[2].Text);
listView3.Items.Add(lvi);
break;//这里是跳出 int k = 0 这个循环
}
}
}
}
追问
谢谢,不过好象不行,我的两个checkedlistbox的内容都是从数据库(MS SQL)表中的字段值,最后还要写入到数据库表3中,我比较迷的是如何通过checkedlist2中选择的值,找出表2中的一行,然后写入表3中,用SQL查询出的一行中各列值如何表示
追答
SQL查询出来的直接结果是datatable型,那就类似
把上面listView2.Items[k].SubItems[0]
这样的改成datatable2.Rows[k][0]
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询