我正在从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)。重启后,程序填充将工作正常,但再次更新将具有相同的效果
答案 0 :(得分:0)
在升级MySQL数据库版本后,我开始面对您在此处发布的相同问题。
我开发了一个C#应用程序,它使用MySqlDataAdapter
Fill()
方法查询MySQL数据库并填充多个数据网格。开发环境中的数据库版本为MySQL Server 5.1.38
。当我在服务器中安装最终数据库时,我使用了同一版本MySQL Server 5.1.73
的最新版本。
当我开始测试应用程序时,我开始得到完全相同的问题:每当通过数据网格对数据进行任何更改时,数据库都会正确更新,但之后,查询数据库的应用程序中的任何数据网格返回0行。在网上搜索后,我发现只有两三个帖子提到同一个问题,但没有回答。到目前为止,摆脱它的唯一方法是卸载升级5.1.73
并再次安装5.1.38
版本。