更新后数据集为空行

时间:2013-06-01 00:20:06

标签: c# mysql dataset rows

我正在从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)。重启后,程序填充将工作正常,但再次更新将具有相同的效果

1 个答案:

答案 0 :(得分:0)

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

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

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