c# linq lambda 去重,排序,取最高纪录。

----------------------------------------------------.对基础类型排序

方法一:

调用sort方法,如果需要降序,进行反转:

List<int> list = new List<int>();

list.Sort();// 升序排序

list.Reverse();// 反转顺序

方法二:

使用lambda表达式,在前面加个负号就是降序了

List<int> list= new List<int>(){5,1,22,11,4};

list.Sort((x, y) => x.CompareTo(y));//升序

list.Sort((x, y) => -x.CompareTo(y));//降序

-------------------------------------------------------------对非基础类型排序

方法一:

修改类本身,实现IComparable<T>接口

//重写的CompareTo方法,根据Id排序

public int CompareTo(People other)

{

if (null == other)

{

return 1;//空值比较大,返回1

}

//return this.Id.CompareTo(other.Id);//升序

return other.Id.CompareTo(this.Id);//降序

}

方法二:

委托

list.Sort(delegate(People p1,People p2)

{

return p1.Id.CompareTo(p2.Id);//升序

});

lambda

list.Sort((x,y)=> { return x.Id.CompareTo(y.Id); });

-------------------------------------------------------------OrderBy

list = list.OrderBy(o => o.Id).ToList();//升序

list = list.OrderByDescending(o => o.Id).ToList();//降序

list = list.OrderBy(o => o.Id).ThenBy(o=>o.Name).ToList();

list = list.OrderByDescending(o => o.Id).ThenByDescending(o=>o.Name).ToList();//降序

---------------------------------------------------------------------------linq 去重

var list_distinct = list.GroupBy(a => new { a.name1, a.name2, a.name3 }).Select(a => a.Key).ToList();

------------------------------------------------------linq 查询金额最高前几条

//

List<ListSortModel> sortedList = (from a in list orderby a.Amount descending select a).Take(data.AmountCount).ToList();

-----------------------------linq取DataTable某一列数据返回给一个List<int>

var list =dt.AsEnumerable().Select<DataRow, int>(x => Convert.ToInt32(x["列名"])).ToList<int>();