0

我正在从 mysql 表中填充 gridview

   public void Init()
   {    

       DataSet dataset = new DataSet();
       dataset = FillGrid();
       bindingSorce.DataSource = dataset.Tables[0];
       gridControl1.DataSource = bindingSorce;
   }

      public static DataSet FillGrid()
    {
        MySqlConnection newConnection = new MySqlConnection(_connectionString);
        try
        {
            DataSet dataset = new DataSet();
            newConnection.Open();
            if (newConnection.State.ToString() == "Open")
            {
                MySqlCommand cmd = new MySqlCommand();
                cmd.Connection = newConnection;
                cmd.CommandText = "SELECT * FROM main";
                MySqlDataAdapter adapter = new MySqlDataAdapter(cmd);
                adapter.Fill(dataset);

            }
            else
            {
                return null;
            }
            newConnection.Close();
            return dataset;
        }
        catch { return null; }
      }

在进行任何更改后,我正在尝试更新 mysql 表

    private void gridView1_RowUpdated(object sender, EventArgs e)
    {
        try
        {
            BindingSource bs = (BindingSource)gridView1.DataSource;
            DataTable changes = ((DataTable)bs.DataSource).GetChanges();       

            if (changes != null)
            {
                bool asd = UpdateGrid(changes);
                ((DataTable)((BindingSource)gridView1.DataSource).DataSource).AcceptChanges();
            }

        }
        catch { }

    }

    public static bool UpdateGrid(DataTable datatable)
    {
        MySqlConnection newConnection = new MySqlConnection(_connectionString);
        //try
        {
            newConnection.Open();
            if (newConnection.State.ToString() == "Open")
            {
                MySqlCommand cmd = new MySqlCommand();
                cmd.Connection = newConnection;
                cmd.CommandText = "SELECT * FROM main";
                MySqlDataAdapter adapter = new MySqlDataAdapter(cmd);
                MySqlCommandBuilder cmb = new MySqlCommandBuilder(adapter);

                //adapter.UpdateCommand = cmb.GetUpdateCommand();
                //adapter.Update(datatable);

                cmb.GetUpdateCommand();
                adapter.Update(datatable);
            }
            else
            {
                return false;
            }
            newConnection.Close();
            return true;
        }
        // catch { return false; }
    }

并且表确实在更新,但是如果在那之后我将调用 Init() 那么 FillGrid() 将返回具有正确列但没有行的数据集!(dataset.tables[0].Rows.count = 0)。重启后程序填充将起作用,但再次更新将具有相同的效果

4

1 回答 1

0

升级 MySQL 数据库版本后,我开始面临您在此处发布的相同问题。

我开发了一个 C# 应用程序,它查询 MySQL 数据库并使用MySqlDataAdapter Fill()方法填充多个数据网格。开发环境中的数据库版本为MySQL Server 5.1.38. 当我在服务器中安装最终数据库时,我使用了相同版本的最新版本,MySQL Server 5.1.73.

当我开始测试应用程序时,我开始遇到完全相同的问题:每当通过数据网格对数据进行任何更改时,数据库都会正确更新,但之后,应用程序中查询数据库的任何数据网格都会返回 0 行。在网上搜索后,我发现只有两三个帖子提到了同一个问题,但没有答案。到目前为止,摆脱它的唯一方法是卸载升级5.1.73并再次安装5.1.38版本。

于 2014-03-10T15:09:29.833 回答