datatable按照某列排序【linq】

/// <summary>
/// 对datatable按照某一列进行linq排序,因为dataview自带的排序处理不了负数的排序【当成字符串处理的?待考究】
/// </summary>
/// <param name="tmpDt">需要排序的datatable</param>
/// <param name="sortId">排序的列序号,从0开始</param>
/// <returns></returns>
protected DataTable LinqSortDataTable(DataTable tmpDt,int sortId)
{
DataView dv = tmpDt.DefaultView;
var query = (from item in tmpDt.AsEnumerable()
orderby Convert.ToInt32(item[sortId])
select item);
//重新排序
dv = query.AsDataView();
return dv.ToTable();
}

posted @ 2012-08-01 10:18  飞来的屋顶  阅读(3020)  评论(0编辑  收藏  举报