C#獲取變更過的DataTable記錄的實現(xiàn)方法
本文實例講述了C#獲取變更過的DataTable記錄的實現(xiàn)方法,是一個非常實用的功能!具體實現(xiàn)方法如下:
首先DataTable可以看做是一個物理表的內(nèi)存式存儲,每一個DataRow都有一個屬性叫做RowState。因此任意一行中某一個字段發(fā)生改變,那么整個DataRow的RowState也就發(fā)生了改變。RowState是一個枚舉,其中包含5個內(nèi)容:
1)Detached:未被附加(一般剛創(chuàng)建的DataRow,或者已經(jīng)被Remove或者RemoveAt,或者Delete之后調(diào)用過AcceptChanges方法的行,或者是WinForm控件DataGridView默認(rèn)設(shè)置下最后那個永遠也留出的空行……都被自動設(shè)置該狀態(tài))。
2)Added:剛添加的新行。
3)Deleted:剛被刪除的行(注意:這里只是從內(nèi)存表中刪除,物理數(shù)據(jù)表中尚未刪除,此時你無法直接去訪問該行的某個字段的內(nèi)容!)。
4)Modified:剛被修改的行。
5)Unchanged:原來的行。
DataTable批量通過內(nèi)部遍歷這些行的RowState,然后借助DataAdapter的CRUD方法根據(jù)這些State調(diào)用不同的語句批量更新到真實數(shù)據(jù)表中。
如果要取消可以調(diào)用DataTable的RejectChanges方法,確認(rèn)從內(nèi)存表中刪除才調(diào)用AcceptChanges方法。
通過DataRow的RowState最多只能判斷哪行被修改,那么調(diào)用不同的語句如何進行更新呢?比如說我要更新一行,肯定使用update……where語句,where后面的條件是一個舊值,set是一個新值,如何獲取舊值呢?
.NET中的DataColumn有一個屬性叫做DataRowVersion,這個屬性有4個:
1)Current:當(dāng)前數(shù)值(DataRowState=Deleted時候無效)。
2)Original:原來數(shù)值(DataRowState=Added或者Unchanged時候無效)。
3)Proposed:建議數(shù)值(僅在DataRowState=Detached的時候有效)。
3)Default:默認(rèn)數(shù)值(DataRowState=Added,Modified或者Unchanged時,等于Current;如果DataRowState=Deleted,等于Original;如果DataRowState=Detached,那么等于Proposed)。該屬性可以自動調(diào)整,你吃不準(zhǔn)哪一行的屬性,一律可以使用這個屬性獲取特定字段的內(nèi)容。
根據(jù)這個法則,我們再結(jié)合微軟DataTable的GetChanges方法輕易可以獲取做了任意變更的源數(shù)據(jù)和現(xiàn)實數(shù)據(jù),具體C#實現(xiàn)代碼如下:
DataTable dt = new DataTable();
dt.Columns.Add("Id");
for (int i = 1; i < 11; i++)
{
dt.Rows.Add(i);
}
dt.AcceptChanges();
//添加第十一行
dt.Rows.Add(11);
//修改第二行
dt.Rows[1][0] = 21;
//刪除第一行
dt.Rows[0].Delete();
//檢索情況
DataTable cdt = dt.GetChanges();
for (int i = 0; i <cdt.Rows.Count; i++)
{
if (cdt.Rows[i].RowState == DataRowState.Deleted)
{
Console.WriteLine("刪除的行索引{0},原來數(shù)值是{1}",i,cdt.Rows[i][0,DataRowVersion.Original]);
}
else if (cdt.Rows[i].RowState == DataRowState.Modified)
{
Console.WriteLine("修改的行索引{0},原來數(shù)值是{1},現(xiàn)在的新數(shù)值{2}", i, cdt.Rows[i][0, DataRowVersion.Original],cdt.Rows[i][0,DataRowVersion.Current]);
}
else if (cdt.Rows[i].RowState == DataRowState.Added)
{
Console.WriteLine("新添加行索引{0},數(shù)值是{1}", i, cdt.Rows[i][0, DataRowVersion.Current]);
}
}
相關(guān)文章
C#實現(xiàn)SSE(Server-Sent Events)服務(wù)端和客戶端的示例代碼
這篇文章主要為大家詳細介紹了C#實現(xiàn)SSE(Server-Sent Events)服務(wù)端和客戶端的相關(guān)知識,文中的示例代碼講解詳細,有需要的小伙伴可以參考下2024-03-03
C#?TaskScheduler任務(wù)調(diào)度器的實現(xiàn)
本文主要介紹了C#?TaskScheduler任務(wù)調(diào)度器的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧<BR>2023-05-05
C#使用IronPython庫調(diào)用Python腳本
這篇文章介紹了C#使用IronPython庫調(diào)用Python腳本的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06
Unity編輯器資源導(dǎo)入處理函數(shù)OnPostprocessTexture實例深入解析
這篇文章主要為大家介紹了Unity編輯器資源導(dǎo)入處理函數(shù)OnPostprocessTexture實例深入解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09
IIS下調(diào)用證書出現(xiàn)異常的解決方法 (C#)
這篇文章主要為大家詳細介紹了IIS下調(diào)用證書出現(xiàn)異常的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05

