今天在做ADO.NET中的adapter進行數據自動觸發更新數據庫功能,發現一個很奇怪的問題,原來數據操作都是自己代碼去完成更新,從來沒有涉及到這種方式,所以一時暈菜了。
1 SQLiteDataAdapter dataAdpater = new SQLiteDataAdapter("Select cid,sd from VC", conn);
2 dataAdpater.DeleteCommand = new SQLiteCommand("delete From VC Where cid = @cid", conn);
3 dataAdpater.DeleteCommand.Parameters.Add("@cid", DbType.Int32, 4, "cid");
4 dataAdpater.DeleteCommand.Parameters["@cid"].SourceVersion = DataRowVersion.Original;
5
6 DataTable categoryTable = new DataTable();
7 dataAdpater.Fill(categoryTable);
8 categoryTable.PrimaryKey = new DataColumn[]{categoryTable.Columns["cid"]};
9
10 DataRow dr = categoryTable.Rows.Find(213213);
11 categoryTable.Rows.Remove(dr);
12 dataAdpater.Update(categoryTable);
執行以上代碼,發現實體數據庫並未刪除,很奇怪,到最后一句debug時對應的213213記錄已經確實不存在,為什么數據庫一直沒有刪除,很困惑,后來查詢MSDN里面發現DataRow有個Delete函數,馬上試試,果然成功刪除。
1 DataRow dr = categoryTable.Rows.Find(213213);
2 dr.Delete();
3 dataAdpater.Update(categoryTable);
查詢MSDN解釋如下:
DataTable.Rows.Remove(row) :Calling Remove is the same as calling Delete and then calling AcceptChanges.
DataTable.Rows[i].Delete():A deleted row can be undeleted by invoking RejectChanges.
這樣意思就很清楚,DataTable里面所有記錄集都有自己的一個修改標志,證明每條記錄是add,delete還是modify的,所有adpater.Update時候就會調用不同的cmd就最終同步是數據,早十年前我同事就用XML返回數據集,本地做離線編輯就是用這方式,最后再一次性提交數據庫,哈,我那同事確實牛!