使用另一个组合框值筛选组合框

本文关键字:组合 筛选 另一个 | 更新日期: 2023-09-27 18:31:55

我有三个组合框,可以过滤不同表中的值。对于前两个组合框我没有问题,但是对于第三个组合框,我得到了错误显示input strings was not in correct format。我对其他两个使用相同的代码,它工作正常。有人可以指定如何解决此问题吗?

这是我的代码:-

这个是用于组合框二,效果很好:-

private void cbBridge_SelectedIndexChanged(object sender, EventArgs e)
{
    if (cbBridge.SelectedValue.ToString() != null)
    {
        int BridgeID = Convert.ToInt32(cbBridge.SelectedValue.ToString());
        FillPier(BridgeID);
    }
}

这是显示错误的代码

private void cbPier_SelectedIndexChanged(object sender, EventArgs e)
{
    if (cbPier.SelectedValue.ToString() != null)
    {
        int PierID = Convert.ToInt32(cbPier.SelectedValue.ToString());
        FillDataPoint(PierID);
    }
}

我希望有人可以告诉我如何纠正这个问题。谢谢。

***更新****

这里是完整的代码

 private void FillPier(int BridgeID)
    {
        SqlConnection con = new SqlConnection(conString);
        SqlCommand cmd = new SqlCommand();
        cmd.Connection = con;
        cmd.CommandType = CommandType.Text;
        cmd.CommandText = "SELECT PierID, PierName, BridgeID FROM tbPier WHERE BridgeID = @BridgeID";
        cmd.Parameters.AddWithValue("@BridgeID", BridgeID);
        DataSet objDs = new DataSet();
        SqlDataAdapter dAdapter = new SqlDataAdapter();
        dAdapter.SelectCommand = cmd;
        con.Open();
        dAdapter.Fill(objDs);
        con.Close();
        if (objDs.Tables[0].Rows.Count > 0)
        {
            cbPier.DataSource = objDs.Tables[0];
            cbPier.DisplayMember = "PierName";
            cbPier.ValueMember = "PierID";
        }
    }
    private void FillDataPoint(int PierDP)
    {
        SqlConnection con = new SqlConnection(conString);
        SqlCommand cmd = new SqlCommand();
        cmd.Connection = con;
        cmd.CommandType = CommandType.Text;
        cmd.CommandText = "SELECT PierID, InspectDate FROM tbDatapoint WHERE PierID = @PierID";
        cmd.Parameters.AddWithValue("@PierID", PierDP);
        DataSet objDs = new DataSet();
        SqlDataAdapter dAdapter = new SqlDataAdapter();
        dAdapter.SelectCommand = cmd;
        con.Open();
        dAdapter.Fill(objDs);
        con.Close();
        if (objDs.Tables[0].Rows.Count > 0)
        {
            cbInspect.DataSource = objDs.Tables[0];
            cbInspect.DisplayMember = "InspectDate";
            cbInspect.ValueMember = "PierID";
        }
    }
    private void ViewBridge_Load(object sender, EventArgs e)
    {
         FillBridge();            
    }
    private void cbBridge_SelectedIndexChanged(object sender, EventArgs e)
    {
        if (cbBridge.SelectedValue.ToString() != null)
        {
            int BridgeID = Convert.ToInt32(cbBridge.SelectedValue.ToString());
            FillPier(BridgeID);
        }
    }

    private void cbPier_SelectedIndexChanged(object sender, EventArgs e)
    {
        if (cbPier.SelectedIndex != 1)
        {
            int PierDP = Convert.ToInt32(cbPier.SelectedValue.ToString());
            FillDataPoint(PierDP);
        }
    }

使用另一个组合框值筛选组合框

检查是否可以像这样先将其转换为 int:

int x = 0
private void cbPier_SelectedIndexChanged(object sender, EventArgs e)
{
    if (Int32.TryParse(cbPier.SelectedValue.ToString(), out x))
    {
        int PierID = Convert.ToInt32(cbPier.SelectedValue.ToString());
        FillDataPoint(PierID);
    }
}

或使用 SelectedIndex 属性:

if(cbPier.SelectedIndex != -1)
{
   .....
}

什么是cbPier.DisplayMembercbPier.ValueMember?diplay 成员是字符串,值成员是 int 吗?首先仔细检查是否是这种情况...