C# 如何在C中从combox向数据网格视图添加值

C# 如何在C中从combox向数据网格视图添加值,c#,C#,我从数据库中检索到组合框中的数据 当从组合框中选择值时,如何将该数据添加到数据网格视图 SqlConnection conn = new SqlConnection(conStr); string query = "select * from products"; SqlCommand cmd = new SqlCommand(query, conn); conn.Open(); SqlDataReader rdr = cmd.E

我从数据库中检索到组合框中的数据

当从组合框中选择值时,如何将该数据添加到数据网格视图

SqlConnection conn = new SqlConnection(conStr);
        string query = "select * from products";
        SqlCommand cmd = new SqlCommand(query, conn);

        conn.Open();
        SqlDataReader rdr = cmd.ExecuteReader();
        while (rdr.Read())
        {
            comboBox3.Items.Add(rdr[0]+"-\t"+rdr[1]+"-"+"Exp Date\t"+rdr[4]);
        }

        conn.Close();

上面是我的代码,用于将数据检索到组合框,

,因此您应该将记录保存在列表、数组等中,例如:

List<string> LstProductos = new List<string>;
对于加载组合框:

foreach(string str in LstProductos)
{
   ComboBox.items.add(str);
}
最后,在您的组合框上:

private void comboBox_SelectedIndexChanged(object sender, EventArgs e)
{
    string YourItem = comboBox1.Text;

    //If you only want to add selected item
    DataGridView.Add(YourItem);

    //or add all
    foreach (string str in LstProductos)
    {
           DataGridView.Rows.Add(str);
    }
}

根据以下设置,有两种方法可以解决您的问题 如果您只想为dataGridView添加一行,那么您只需要根据以下方法1使用列表的概念

但如果您想在从组合框中选择时添加更多行,那么您将使用DataTableMethod2。请注意,DataTable还包括GridView中从ComboBox中选择的productID列的primaryKey

如果要删除主键,请在Method2中注释主键的代码

方法1:


保持幸福

您期望的组合框值和文本是什么样子的?组合框文本包括产品id、产品名称和有效期,我希望在单击其中一个时将其插入数据网格视图。
private void comboBox_SelectedIndexChanged(object sender, EventArgs e)
{
    string YourItem = comboBox1.Text;

    //If you only want to add selected item
    DataGridView.Add(YourItem);

    //or add all
    foreach (string str in LstProductos)
    {
           DataGridView.Rows.Add(str);
    }
}
public class GridviewData
{
    public string ProductId{set;get;}
    public string ProductName { set; get; }
    public string ExpireDate { set; get; }
}
public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();
    }
    private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
    {
        string selectedItem = comboBox1.SelectedItem.ToString();
        List<string> dataList = selectedItem.Split('-').ToList();
        GridviewData data = new GridviewData();
        data.ProductId = dataList[0];
        data.ProductName = dataList[1];
        data.ExpireDate = dataList[2];
        List<GridviewData> gridviewList = new List<GridviewData>();
        gridviewList.Add(data);
        dataGridView1.DataSource = gridviewList;
    }
}
public partial class Form1 : Form
{
    DataTable dt = new DataTable();
    public Form1()
    {
        InitializeComponent();
        DataColumn productID = new DataColumn();
        productID.ColumnName = "Product ID";
        dt.Columns.Add(productID);
        dt.Columns.Add("Product Name");
        dt.Columns.Add("Expire Date");
        dt.PrimaryKey = new DataColumn[] {productID };//if you want to set primary key for dataTable upon productID
    }
    private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
    {
        try
        {
            string selectedItem = comboBox1.SelectedItem.ToString();
            List<string> data = selectedItem.Split('-').ToList();
            dt.Rows.Add(new object[] { data[0], data[1], data[2] });
            dataGridView1.DataSource = dt;
        }
        catch(Exception er)
        {
            MessageBox.Show(er.Message);
        }
    }
}
//dt.PrimaryKey = new DataColumn[] {productID };