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>();



猜你喜欢

转载自www.cnblogs.com/j2ee-web-01/p/10346173.html