sort.java

来自「使用Java语言和SQL Server数据库实现员工信息管理系统」· Java 代码 · 共 121 行

JAVA
121
字号
/**
 * @author: WangJinTao,MengQingChang 2006 
 */
package swtjfaceExample;

import org.eclipse.jface.viewers.Viewer;
import org.eclipse.jface.viewers.ViewerSorter;

// 排序器类Sort继承ViewerSorter类
public class Sort extends ViewerSorter {

	private int column;

	/**
	 * 接受TableViewerSort类中((Sort) tv.getSorter()).doSort()语句中
	 * doSort()方法中的参数取值,该值即为列号 ,
	 */
	public void doSort(int column) {
		this.column = column;
	}

	public int compare(Viewer viewer, Object e1, Object e2) {

		Employee p1 = (Employee) e1;
		Employee p2 = (Employee) e2;
		// 根据列的取值来进行对应列的降序、升序排列表记录
		switch (column) {
		case 1: {
			Integer str1 = p1.getID();
			Integer str2 = p2.getID();
			int IDDesc = str2.compareTo(str1);
			return IDDesc;
		}

		case -1: {
			Integer str1 = p1.getID();
			Integer str2 = p2.getID();
			int IDAsc = str1.compareTo(str2);

			return IDAsc;
		}

		case 2: {
			String str1 = p1.getName();
			String str2 = p2.getName();
			int NameDesc = str2.compareTo(str1);
			return NameDesc;
		}

		case -2: {
			String str1 = p1.getName();
			String str2 = p2.getName();
			int NameAsc = str1.compareTo(str2);

			return NameAsc;
		}

		case 3: {
			String str1 = p1.getSex();
			String str2 = p2.getSex();
			int SexDesc = str2.compareTo(str1);
			return SexDesc;
		}

		case -3: {
			String str1 = p1.getSex();
			String str2 = p2.getSex();
			int SexAsc = str1.compareTo(str2);

			return SexAsc;
		}
		case 4: {
			Integer str1 = p1.getAge();
			Integer str2 = p2.getAge();
			Integer AgeDesc = str2.compareTo(str1);
			return AgeDesc;
		}

		case -4: {
			Integer str1 = p1.getAge();
			Integer str2 = p2.getAge();
			int AgeAsc = str1.compareTo(str2);

			return AgeAsc;
		}

		case 5: {
			String str1 = p1.getPosition();
			String str2 = p2.getPosition();
			int PositionDesc = str2.compareTo(str1);
			return PositionDesc;
		}

		case -5: {
			String str1 = p1.getPosition();
			String str2 = p2.getPosition();
			int PositionAsc = str1.compareTo(str2);

			return PositionAsc;
		}
		case 6: {
			Integer str1 = p1.getSalary();
			Integer str2 = p2.getSalary();
			int SalaryDesc = str2.compareTo(str1);
			return SalaryDesc;
		}

		case -6: {
			Integer str1 = p1.getSalary();
			Integer str2 = p2.getSalary();
			int SalaryAsc = str1.compareTo(str2);

			return SalaryAsc;
		}
		}

		return 0;

	}

}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?