c# - MySqlDataAdapter使用Update以后在使用Fill填充Table时得不到数据
问题描述
在wpf中从数据库读取到的数据binding到DataGrid,然后将修改后的DataTable更新到数据库中第一次select查询以及绑定没有问题,updateDataTable到数据库,数据库中的数据被更新,然后再次使用select的时候就再也查询不到数据,重新声明这个类都没有效果,除非重启软件,请问是那里出的问题,代码如下:
public class IDbMysql{ MySqlConnection db_conn; public IDbMysql(string ip, int port, string userName, string userPwd, string database) {string str_db_conn = string.Format('Server={0};Port={1};Database={2};Username={3};Password={4};charset=utf8;', ip, port, database, userName, userPwd);db_conn = new MySqlConnection(str_db_conn);db_conn.Open(); } public DataTable select(string db_string) {DataTable dt = new DataTable();MySqlDataAdapter adapter = new MySqlDataAdapter(db_string, db_conn);adapter.Fill(dt);return dt; } public int updateDataTable(string db_string, DataTable db_datatable) {int ret = -1;MySqlDataAdapter adapter = new MySqlDataAdapter(db_string, db_conn);MySqlCommandBuilder builder = new MySqlCommandBuilder(adapter);ret = adapter.Update(db_datatable);return ret; }}
调用函数过程:
IDbMysql db = new IDbMysql();DataTable dt = db.select('select * from tableA');// 这里是对dt的修改,省略一些代码db.updateDataTable(dt); // 这里执行都是成功的,数据库也修改了DataTable dtNew = db.select('select * from tableA'); // 这里就查询不到数据了,然会0条数据,但是数据库里面是可以看到数据的
问题解答
回答1:碰到同样的问题,求助怎么解决的
相关文章:
1. javascript - vue 数据更新了。但是dom没有更新,,,,,如图2. html5 - 百度Ueditor代码高亮和代码段滚动条冲突是怎么回事?3. javascript - 读取页面源码,页面中所有的换行都被当成<br/>读取出来 了,,求解应该怎么让它被正确的解析4. javascript - 静态页面引公共头尾文件,js怎么写吖?5. debian - docker依赖的aufs-tools源码哪里可以找到啊?6. css - 关于input标签disabled问题7. 如何调整IDEA中直接运行java程序的日志输出级别?8. javascript - 关于一段 for 循环代码执行顺序的问题9. java基础,求解答。10. java - 为什么要将Runnable接口的子类对象传递给Thread的构造函数?