读书人

灵便使用DataView

发布时间: 2012-10-20 14:12:48 作者: rapoo

灵活使用DataView

????????????????{
????????????????????dr?=?dt.NewRow();
????????????????????dr["DateType"]?=?ds.Tables[0].Rows[intI?-?1?+?1]["DateType"].ToString();
????????????????????dr["TCOrder"]?=?ds.Tables[0].Rows[intI?-?1?+?1]["TCOrder"].ToString();
????????????????????dr["TimeClass_ID"]?=?intNewID;
????????????????????dr["TimeClass_Name"]?=?ds.Tables[0].Rows[intI?-?1?+?1]["TimeClass_Name"].ToString();
????????????????????dr["Chn_NameLocal"]?=?ds.Tables[0].Rows[intI?-?1?+?1]["Chn_NameLocal"].ToString();
????????????????????dr["User_Name"]?=?ds.Tables[0].Rows[intI?-?1?+?1]["User_Name"].ToString();
????????????????????dr["User_ID"]?=?ds.Tables[0].Rows[intI?-?1?+?1]["User_ID"].ToString();
????????????????????dt.Rows.Add(dr);
????????????????????dt.AcceptChanges();
????????????????????intNewID++;
????????????????}

????????????????dtRst?=?dt.Copy();
????????????????dtRst.Clear();
????????????????FoundRow?=?dt.Select("1?=?1",?"TimeClass_Name,?DateType,?TCOrder");
????????????????for(int?intI?=?0;intI?<?FoundRow.Length;intI++)
????????????????{
????????????????????dr?=?dtRst.NewRow();
????????????????????dr["DateType"]?=?FoundRow[intI]["DateType"].ToString();
????????????????????dr["TCOrder"]?=?FoundRow[intI]["TCOrder"].ToString();
????????????????????dr["TimeClass_ID"]?=?FoundRow[intI]["TimeClass_ID"].ToString();
????????????????????dr["TimeClass_Name"]?=?FoundRow[intI]["TimeClass_Name"].ToString();
????????????????????dr["Chn_NameLocal"]?=?FoundRow[intI]["Chn_NameLocal"].ToString();
????????????????????dr["User_Name"]?=?FoundRow[intI]["User_Name"].ToString();
????????????????????dr["User_ID"]?=?FoundRow[intI]["User_ID"].ToString();
????????????????????dtRst.Rows.Add(dr);
????????????????????dtRst.AcceptChanges();
????????????????}

????????????????DatagridTC.DataSource?=?dtRst;
????????????????DatagridTC.DataBind();
另外一个写法是:
DataView?dv?=?ds.Tables[0].DefaultView;
????????????????dv.Sort?=?"TimeClass_Name,?DateType,?TCOrder";
????????????????DatagridTC.DataSource?=?dv;
????????????????DatagridTC.DataBind();

显然方法二从代码上就简洁多了,更重要的是它不要再新创建dataset等,减少了内存和CPU的消耗。

因此大家在遇到需要排序或者过滤数据的时候,要多想想可否使用dataview来实现了。

<script type="text/javascript">if ($ != jQuery) {$ = jQuery.noConflict();}var isLogined = false;var cb_blogId = 7691;var cb_entryId = 160881;var cb_blogApp = "jimmyhsu";var cb_blogUserGuid = "bd8e310b-63cf-dd11-9e4d-001cf0cd104b";var cb_entryCreatedDate = '2005/5/23 10:43:00';</script>分类: .net技术

读书人网 >Web前端

热点推荐