-1

我有一个包含客户端列表的数据表,然后将其分配给组合框的数据源。

然后,我有另一个包含客户端站点列表的数据表,当组合框发生更改时,它应该对站点数据表执行选择并仅返回匹配并填充站点组合框的行。

问题是它返回 System.Data.DataRow 而不是 sitename 列中包含的数据!

public frmTechSupportCall()
{
    cboxClientName.DataSource = parentfrm._ClientsList;
    cboxClientName.DisplayMember = "companyname";
    cboxClientName.ValueMember = "client_id";
    cboxClientName.SelectedIndex = 1;
    cboxClientName.Refresh();
}
private void cboxClientName_SelectedIndexChanged(object sender, EventArgs e)
{
    //var temp = cboxClientName.SelectedValue;            

    if (cboxClientName.SelectedValue.GetType().ToString() == "System.Int32")
    {
        //DataRow[] dr = parentfrm._ClientsSites.Select(@"client_id = " + cboxClientName.SelectedValue);                
        cboxClientSite.DisplayMember = "sitename";
        cboxClientSite.ValueMember = "site_id";
        cboxClientSite.DataSource = parentfrm._ClientsSites.Select(@"client_id = " + cboxClientName.SelectedValue);
        //cboxClientSite.BindingContext = this.BindingContext;
        //_ClientsList.Rows.InsertAt(drow, 0);
        //cboxClientSite.Items.Add(new object[] { 0, "--Please Select --" });
        //cboxClientSite.SelectedIndex = 0;
    }
}
4

1 回答 1

1

像这样做

cboxClientSite.DataSource = parentfrm._ClientsSites.Select(@"client_id = " + cboxClientName.SelectedValue).CopyToDataTable();
于 2013-08-05T12:28:45.707 回答