linq 实现动态 orderby

推荐:http://www.cnblogs.com/roucheng/p/dushubiji.html

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

class Pet  
{  
   public string Name{get;set;}  
   public int Age{get;set;}  
}  
void Main()  
{   
      Pet[] pets = { new Pet { Name="Tim", Age=18 },  
                   new Pet { Name="Allen", Age=22 },  
                   new Pet { Name="Bill", Age=20  } };  
       
//如果我们想根据Age进行排序  很容易想到这样来写:      
  var query= from p in pets  
             orderby p.Age  
             select p;  
               
       
  query.ToList().ForEach(q=>Console.WriteLine(q.Name +"     "+q.Age));  
        /* 得到结果:  
        Tim     18 
        Bill    20 
        Allen   22 
        */  
          
}  
//但是有时项目内有多个排序条件 如有时要根据Name排序 有时要根据Age排序  何问起 hovertree.com
       //这时我们就要用到动态排序:  
void Main()  
{   
    Pet[] pets = { new Pet { Name="Tim", Age=18 },  
                   new Pet { Name="Allen", Age=22 },  
                   new Pet { Name="Bill", Age=20 } };  
    Console.WriteLine("Before Orderby:/r/n");         
    pets.ToList().ForEach(p=>Console.WriteLine(p.Name +"     "+p.Age));  
       
  var query= from p in pets  
             orderby GetPropertyValue(p,"Age")    
             select p;  
               
    Console.WriteLine("/r/nAfter Orderby:/r/n");  
  query.ToList().ForEach(q=>Console.WriteLine(q.Name +"     "+q.Age));  
           /* 
        Before Orderby: 
        Tim     18 
        Allen   22 
        Bill    20 
        After Orderby: 
         
        Tim     18 
        Bill    20 
        Allen   22 
        */         
}  /* 何问起 hovertree.com */
private static object GetPropertyValue(object obj, string property)  
{  
    System.Reflection.PropertyInfo propertyInfo=obj.GetType().GetProperty(property);  
    return propertyInfo.GetValue(obj, null);  
} 

推荐:http://www.cnblogs.com/roucheng/p/dushubiji.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/120405.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何将XPS文档转成Excel表格?

    如何将XPS文档转成Excel表格?今天收到一个XPS文档,打开文档后发现里面的内容都是数据,使用Excel用公式整理会非常方便,那么如何将XPS文件转换成表格呢?搜索了一圈虽然没有找到XPS转Excel工具,但却找到好用的XPS转PDF方法,于是只能曲线救国先转成PDF再PDF转Excel。方法1:在线转换首先打开speedpdf在线转换工具,选择XPS转PDF进入转换,接着添加需要转换的XPS文件后,点击转换,等待转换完成后点击下载,最后再点击左侧列表中的PDF转Excel,并添加上一步中下载的PDF文档转换即可。如果需要转换的

    2022年5月5日
    352
  • executeUpdate()返回值「建议收藏」

    executeUpdate()返回值「建议收藏」executeUpdate()是PreparedStatement对象众多的抽象方法中的一个在jdk1.8中executeUpdate()有两种返回值(搜索一下PreparedStatement即可查看到),即有两种返回值不同的方法。返回值分别是:int和ResultSet在使用数据库的项目中作者用到了返回值为int的方法,查询了一下相关的解释intexecuteUpdate()…

    2022年10月20日
    1
  • 【单片机】51单片机最小系统

    【单片机】51单片机最小系统51单片机最小系统由三部分组成:主控电路、复位电路、晶振电路。添加LED电路和独立按键。原理图如下所示:

    2022年6月23日
    19
  • 什么是光栅化?_光栅成像

    什么是光栅化?_光栅成像光栅化首先,光栅化(Rasterize/rasteriztion)。这个词儿Adobe官方翻译成栅格化或者像素化。没错,就是把矢量图形转化成像素点儿的过程。我们屏幕上显示的画面都是由像素组成,而三维物体都是点线面构成的。要让点线面,变成能在屏幕上显示的像素,就需要Rasterize这个过程。就是从矢量的点线面的描述,变成像素的描述。如下图,这是一个放大了1200%的屏幕,前面是告诉计算机我有一个圆形,后面就是计算机把圆形转换成可以显示的像素点。这个过程就是Rasterize。参考链接如何理解Open

    2022年10月19日
    1
  • Oracle Sqlplus 运行环境 login.sql 设置[通俗易懂]

    Oracle Sqlplus 运行环境 login.sql 设置[通俗易懂]在运行Sqlplus时经常需要对运行环境进行设置,如果每次输入都要调整参数会比较麻烦,因此可以利用Oracle提供的glogin.sql、login.sql这两个文件对Sqlplus进行环境初始化。

    2022年7月16日
    17
  • nginx purge 根 / 缓存

    nginx purge 根 / 缓存

    2021年8月22日
    56

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号