我在C#中有一个带有几个comboboxes
的winforms应用程序。这些组合框显示来自SQL数据库的数据。我可以让组合框在listview
中显示数据,但我想要的是过滤数据。
例如,用户在combobox1中选择一个值并显示结果,但是当他在combobox
2中选择一个值时,只会显示带有combobox1
规则的相应值。
这就像创建一个过滤器,但我无法弄清楚我如何在组合框之间进行交互。
我的代码是:
private void desempenho_SelectedIndexChanged(object sender, EventArgs e)
{
SqlDataAdapter sda = new SqlDataAdapter(@"select [desc],[enchimento],[compo] from vidros where desempenho = @emp", con);
sda.SelectCommand.Parameters.Add("@emp", SqlDbType.NVarChar).Value = desempenho.Text;
DataTable DTT = new DataTable();
sda.Fill(DTT);
listView1.Items.Clear();
for (int i = 0; i < DTT.Rows.Count; i++)
{
DataRow dr = DTT.Rows[i];
ListViewItem listitem = new ListViewItem(dr["desc"].ToString());
listitem.SubItems.Add(dr["enchimento"].ToString());
listitem.SubItems.Add(dr["compo"].ToString());
listView1.Items.Add(listitem);
}
}
private void valu_SelectedIndexChanged(object sender, EventArgs e)
{
SqlDataAdapter SDA2 = new SqlDataAdapter(@"select [desc],[enchimento],[compo] from vidros where valu = @emp2", con);
SDA2.SelectCommand.Parameters.Add("@emp2", SqlDbType.NVarChar).Value = valu.Text;
DataTable DTT2 = new DataTable();
SDA2.Fill(DTT2);
listView1.Items.Clear();
for (int i = 0; i < DTT2.Rows.Count; i++)
{
DataRow dr = DTT2.Rows[i];
ListViewItem listitem = new ListViewItem(dr["desc"].ToString());
listitem.SubItems.Add(dr["enchimento"].ToString());
listitem.SubItems.Add(dr["compo"].ToString());
listView1.Items.Add(listitem);
}
这只适用于两个组合框,但是当我使用这个组合框时,剩下的就很简单了。
提前致谢,
答案 0 :(得分:2)
这应该做你需要的事情。它的伪代码和未经测试的代码,但将遍历表单上的每个组合框,然后您可以使用列表中的值执行您想要的操作
void Main()
{
var cb1 = new ComboBox()
var cb2 = new ComboBox()
var frm = new Form()
var selectedItemAndValue = new List<selectedItem>();
foreach (Control ctrl in frm.Controls)
{
if (ctrl.GetType() == typeof(ComboBox)
{
var cb = ctrl as ComboBox
selectedItemAndValue.Add(new selectedItem {
Idx = cb.SelectedIndex,
Text = cb.SelectedText,
Value = cb.SelectedValue.ToString()})
}
//the above code will then give you a list of everything that is selected in each of your combo boxes
}
}
public class selectedItem
{
public int Idx { get; set; }
public string Text { get; set; }
public string Value {get; set;}
}
// Define other methods and classes here