0

我正在使用 linq4j。我只按一个属性排序,并想按多个属性排序。如果 linq4j 不支持,那么我可以使用其他方法。以下是我的代码片段,

import java.util.Arrays;
import java.util.List; 
import net.hydromatic.linq4j.Linq4j;
import net.hydromatic.linq4j.function.*;

public class Linq4jExample {
 public static class Employee {
 public final int empno;
 public final String name;
 public final int deptno;

public Employee(int empno, String name, int deptno) {
  this.empno = empno;
  this.name = name;
  this.deptno = deptno;
}

public String toString() {
  return "Employee(empno: " + empno +",name: " + name + ", deptno:" + deptno    + ")";
 }
 }

public static final Employee[] emps = {
  new Employee(100, "Fred", 10),
  new Employee(110, "Bill", 30),
  new Employee(120,  "Bill", 10),
  new Employee(120, "Eric", 12),
  new Employee(130, "Janet", 13),
};

public static final Function1<Employee, Integer> EMP_DEPTNO_SELECTOR =
  new Function1<Employee, Integer>() {
    public Integer apply(Employee employee) {
      return employee.deptno;
    }
     };

public static void main(String[] args) {

  List<Employee> filter=Linq4j.asEnumerable(Arrays.asList(emps)) 
            .orderBy(new Function1<Employee,String>()
        { 
        public String apply(Employee arg0)
        {
            return arg0.name;
        }

    }).toList();

  }
 }

一个潜在的用例可能是按部门编号然后按名称排序

4

1 回答 1

1

您可以在 linq4j 中有多个 order by。检查以下示例

package maven_lab;

import java.util.Arrays;
import java.util.List;

import org.apache.calcite.linq4j.Linq4j;
import org.apache.calcite.linq4j.function.Function1;

public class Linq4jExample {

    public static final Employee[] emps = {
            new Employee(100, "Fred", 10),
            new Employee(110, "Bill", 30),
            new Employee(120, "Bill", 10),
            new Employee(120, "henry", 10),
            new Employee(120, "Adam", 10),
            new Employee(120, "Eric", 12),
            new Employee(130, "Janet", 13),
    };

    public static final Function1<Employee, Integer> EMP_DEPTNO_SELECTOR =
            new Function1<Employee, Integer>() {
                public Integer apply(Employee employee) {
                    return employee.deptno;
                }
            };

    public static void main(String[] args) {

        List<Employee> filter = Linq4j.asEnumerable(Arrays.asList(emps)).orderBy(e -> e.deptno)
            .orderBy(e -> e.name).toList();

        System.out.println(filter);

    }

    public static class Employee {
        public final int empno;
        public final String name;
        public final int deptno;

        public Employee(int empno, String name, int deptno) {
            this.empno = empno;
            this.name = name;
            this.deptno = deptno;
        }

        public String toString() {
            return "Employee(empno: " + empno + ",name: " + name + ", deptno:" + deptno + ")";
        }
    }


}

请注意,我先按部门排序,然后按名称排序。您还应该使用 jdk8 lambda 而不是匿名类。


在 JDK8 之前,您可以这样做,如下所示,

 List<Employee> filter = Linq4j.asEnumerable(Arrays.asList(emps)).orderBy(new Function1<Employee, Integer>() {
            public Integer apply(Employee arg0) {
                return arg0.deptno;
            }

        }).orderBy(new Function1<Employee, String>() {
            public String apply(Employee arg0) {
                return arg0.name;
            }

        }).toList();
于 2017-03-10T04:50:51.207 回答