【问题标题】:C# update combobox with Database valuesC# 使用数据库值更新组合框
【发布时间】:2020-08-20 03:58:09
【问题描述】:

您好,我有一个包含驱动程序的数据库和一个包含驱动程序的组合框。但是当我使用添加驱动程序按钮添加新驱动程序时,它只添加到 Microsoft Access 表中,而不是组合框中。一旦我重新加载程序,新的驱动程序就会从数据库中删除。我还连接了数据源中的数据库,我只能从那里编辑表(如果我想编辑组合框)。

这是我与数据库的连接

private void Form1_Load(object sender, EventArgs e)
{
    con = new OleDbConnection("Provider=Microsoft.ACE.Oledb.12.0;Data Source=transportDateBase.accdb");
    cmd = new OleDbCommand();
    con.Open();
    cmd.Connection = con;
    string query = "SELECT Name FROM Drivers";
    cmd.CommandText = query;
    OleDbDataReader reader = cmd.ExecuteReader();
    while (reader.Read())
    {
        comboDriver.Items.Add(reader["Name"]);
    }
    con.Close();

这是我的添加驱动程序按钮:

OleDbConnection conn = new OleDbConnection();
conn.ConnectionString = ("Provider=Microsoft.ACE.Oledb.12.0;Data Source=transportDateBase.accdb");

String Id = textID.Text;
String Name = textName.Text;
String Age = textAge.Text;
String City = textCity.Text;

OleDbCommand cmd = new OleDbCommand("INSERT into Drivers (Id, Name, Age, City) Values(@Id, @Name, @Age, @City)");
cmd.Connection = conn;

conn.Open();

if (conn.State == ConnectionState.Open)
{
    cmd.Parameters.Add("@Id", OleDbType.VarChar).Value = Id;
    cmd.Parameters.Add("@Name", OleDbType.VarChar).Value = Name;
    cmd.Parameters.Add("@Age", OleDbType.VarChar).Value = Age;
    cmd.Parameters.Add("@City", OleDbType.VarChar).Value = City;

    try
    {
        cmd.ExecuteNonQuery();
        MessageBox.Show("New Driver Added");
        conn.Close();
    }
    catch (OleDbException ex)
    {
        MessageBox.Show(ex.Source);
        conn.Close();
    }

【问题讨论】:

    标签: c# database combobox


    【解决方案1】:

    仅仅因为您已将其添加到数据库中,并不意味着会发生任何其他事情。

    您仍然需要更新您的用户界面。

    在执行查询后添加:

    comboDriver.Items.Add(Name);
    

    顺便说一句,您还应该将 conn.Open() 包装在 try catch 中

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-02-01
      • 1970-01-01
      • 1970-01-01
      • 2022-01-23
      • 2012-05-12
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多