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. mysql - eclispe無法打開數據庫連接2. css3 - 沒明白盒子的height隨width的變化這段css是怎樣實現的?3. javascript - 在 model里定義的 引用表模型時,model為undefined。4. javascript - 一個關于客戶端和前端通信的疑惑?5. java - 根據月份查詢多個表里的內容怎么實現好?6. css3 - 這個右下角折角用css怎么畫出來?7. javascript - webpack熱加載配置不生效8. debian - docker依賴的aufs-tools源碼哪里可以找到啊?9. python3.x - c++調用python310. android - 課程表點擊后浮動后邊透明可以左右滑動的界面是什么?
