揭秘ADO.NET性能原理分析
ADO.NET越來越多的人使用,它也很快速的發展起來,在ADO.NET2.0中它的數據交互性能也有很大的提升,DataTable的功能被大大增強了。畢竟我們不是時時需要Dataset,這里我們就ADO.NET性能來深入的探討一下吧。
#T#1.ADO.NET性能裝載XML數據
在 ADO.NET 1.* 時,離線的數據訪問模型以 DataSet 對象為主,因此若要將 XML 的數據裝載到 DataTable,必須通過 DataSet 來實現。若我們僅操作一個數據表,不需要訪問多個數據表,則還需經過 DataSet 類才能賦予 DataTable 數據或將數據輸出成 XML
文件,其過程有點繁瑣。ADO.NET 2.0 的 DataTable 類則新增了與 DataSet 相同的。ReadXML、ReadXMLSchema、WriteXML 以及WriteXMLSchema 等方法。因此我們可以直接操作 DataTable 實例,而不需先創建 DataSet 類的實例來賦予 DataTable 實例數據,然后只使用 DataTable 實例。
2.ADO.NET性能結果集直接裝載DataTable
可以通過DataTableReader對象生成DataTable和DataSet。利用DataTable和DataSet在2.0版本中新引入的方法Load,可以傳遞DataTableReader或者任何實現IDataReader接口的類對象。下面的代碼就是通過Load方法將dt1的數據傳遞到新的數據表dt2中:
- DataTableReader dtRdr = dt1.CreateDataReader();
- DataTable dt2 = new DataTable(); dt2.Load(dtRdr);
在使用Load方法裝載多行數據時,可以先調用BeginLoadData方法來避免通知 (notifications),索引維護(index maintenance)以及約束檢查(constraint checking),然后再通過EndLoadData方法返回數據。
3.通過 SqlDataAdapter 類實例將 DataTable 內的記錄更新回數據源
現在我們還可以使用 SqlDataAdapter 類實例通過 DataGridView 更新的記錄。
Update方法由以下幾個重載:
- public int Update(DataRow[] dataRows);
- public override int Update(DataSet dataSet);
- public int Update(DataTable dataTable);
- public int Update(DataSet dataSet, string srcTable);