메뉴 건너뛰기

Cloudera, BigData, Semantic IoT, Hadoop, NoSQL

Cloudera CDH/CDP 및 Hadoop EcoSystem, Semantic IoT등의 개발/운영 기술을 정리합니다. gooper@gooper.com로 문의 주세요.


*출처 : http://forum.falinux.com/zbxe/index.php?document_srl=572949&mid=lecture_tip


Test2.java소스

package com.gooper.icbms.sda.comm.util;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
  
  
public class Test2 {
  
    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        List<User> users = getCreateUsers();
  
        System.out.println("===== 정렬 하기전 =====");
        for (User temp : users) {
            System.out.println(temp);
        }
  
        Collections.sort(users, new NameAscCompare());
        System.out.printf("nn===== 이름 오름 차순 정렬 =====n");
        for (User temp : users) {
            System.out.println(temp);
        }
  
        Collections.sort(users, new NameDescCompare());
        System.out.printf("nn===== 이름 내림 차순 정렬 =====n");
        for (User temp : users) {
            System.out.println(temp);
        }
  
        Collections.sort(users, new NoAscCompare());
        System.out.printf("nn===== No 오름 차순 정렬 =====n");
        for (User temp : users) {
            System.out.println(temp);
        }
  
        Collections.sort(users, new NoDescCompare());
        System.out.printf("nn===== No 내림 차순 정렬 =====n");
        for (User temp : users) {
            System.out.println(temp);
        }

        Collections.sort(users, new NameAscNoDescCompare());
        System.out.printf("nn===== Name asc + No desc 정렬 =====n");
        for (User temp : users) {
            System.out.println(temp);
        }

        
    }
  
  
    /**
     * User Data Create
     * @return
     */
     private static List<User> getCreateUsers() {
        // TODO Auto-generated method stub
         List<User> users = new ArrayList<User>();
  
         User user = new User();
         user.setName("고철수");
         user.setAddress("경기도 성남시 분당구");
         user.setPhone("010-1234-0192");
         user.setNo(1);
         users.add(user);

         user = new User();
         user.setName("고철수");
         user.setAddress("경기도 성남시 분당구");
         user.setPhone("010-1234-0192");
         user.setNo(5);
         users.add(user);

  
         user = new User();
         user.setName("박영희");
         user.setAddress("부산 해운대");
         user.setPhone("010-4234-0192");
         user.setNo(2);
         users.add(user);
  
  
         user = new User();
         user.setName("감수왕");
         user.setAddress("충북 제천");
         user.setPhone("010-7234-0192");
         user.setNo(3);
         users.add(user);
  
  
         user = new User();
         user.setName("이사람");
         user.setAddress("강원도 영울");
         user.setPhone("010-0234-0192");
         user.setNo(4);
         users.add(user);
        return users;
    }
  
  
     /**
      * 이름 오름차순
      * @author falbb
      *
      */
    static class NameAscCompare implements Comparator<User> {
  
        /**
         * 오름차순(ASC)
         */
        @Override
        public int compare(User arg0, User arg1) {
            // TODO Auto-generated method stub
            return arg0.getName().compareTo(arg1.getName());
        }
  
    }
    
    
    /**
     * Name asc + No desc
     * @author falbb
     *
     */
   static class NameAscNoDescCompare implements Comparator<User> {
 
       /**
        * Name으로 오름차순(ASC) 정렬후 Name이 같으면 No로 내림차순 정렬(desc)
        */
       @Override
       public int compare(User arg0, User arg1) {
    	   String name1 = arg0.getName();
    	   String name2 = arg1.getName();
    	   
    	   int ret = 0;
    	   ret = name1.compareTo(name2); 
    	   
    	   if(ret == 0) {
    		   int no1 = arg0.getNo();
    		   int no2 = arg1.getNo();
    		   if(no2 > no1) {
    			   ret = -1; 
    		   } else if(no2 > no1) {
    			   ret = 1;
    		   } else {
    			   ret = 0;
    		   }
    	   }
    	   
           return ret;
       }
 
   }

   
  
    /**
     * 이름 내림차순
     * @author falbb
     *
     */
    static class NameDescCompare implements Comparator<User> {
  
        /**
         * 내림차순(DESC)
         */
        @Override
        public int compare(User arg0, User arg1) {
            // TODO Auto-generated method stub
            return arg1.getName().compareTo(arg0.getName());
        }
  
    }
  
     /**
      * No 오름차순
      * @author falbb
      *
      */
    static class NoAscCompare implements Comparator<User> {
  
        /**
         * 오름차순(ASC)
         */
        @Override
        public int compare(User arg0, User arg1) {
            // TODO Auto-generated method stub
            return arg0.getNo() < arg1.getNo() ? -1 : arg0.getNo() > arg1.getNo() ? 1:0;
        }
  
    }
  
    /**
     * No 내림차순
     * @author falbb
     *
     */
    static class NoDescCompare implements Comparator<User> {
  
        /**
         * 내림차순(DESC)
         */
        @Override
        public int compare(User arg0, User arg1) {
            // TODO Auto-generated method stub
            return arg0.getNo() > arg1.getNo() ? -1 : arg0.getNo() < arg1.getNo() ? 1:0;
        }
  
    }
    
    static class User {
    	
		private String name;
        private String address;
        private String phone;
        private int no; 
        
        public String getName() {
			return name;
		}
		public void setName(String name) {
			this.name = name;
		}
		public String getAddress() {
			return address;
		}
		public void setAddress(String address) {
			this.address = address;
		}
		public String getPhone() {
			return phone;
		}
		public void setPhone(String phone) {
			this.phone = phone;
		}
		public int getNo() {
			return no;
		}
		public void setNo(int no) {
			this.no = no;
		}
		@Override
		public String toString() {
			return "User [name=" + name + ", address=" + address + ", phone="
					+ phone + ", no=" + no + "]";
		}

     }
}


* 문자열 비교compareTo처럼 숫자도 비교 해서  결과 값을 -1, 0, 1을 리턴 해주면 됩니다.

-1:작다

0:같다

1:크다


-->실행결과

===== 정렬 하기전 =====
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=1]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=5]
User [name=박영희, address=부산 해운대, phone=010-4234-0192, no=2]
User [name=감수왕, address=충북 제천, phone=010-7234-0192, no=3]
User [name=이사람, address=강원도 영울, phone=010-0234-0192, no=4]


===== 이름 오름 차순 정렬 =====
User [name=감수왕, address=충북 제천, phone=010-7234-0192, no=3]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=1]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=5]
User [name=박영희, address=부산 해운대, phone=010-4234-0192, no=2]
User [name=이사람, address=강원도 영울, phone=010-0234-0192, no=4]


===== 이름 내림 차순 정렬 =====
User [name=이사람, address=강원도 영울, phone=010-0234-0192, no=4]
User [name=박영희, address=부산 해운대, phone=010-4234-0192, no=2]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=1]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=5]
User [name=감수왕, address=충북 제천, phone=010-7234-0192, no=3]


===== No 오름 차순 정렬 =====
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=1]
User [name=박영희, address=부산 해운대, phone=010-4234-0192, no=2]
User [name=감수왕, address=충북 제천, phone=010-7234-0192, no=3]
User [name=이사람, address=강원도 영울, phone=010-0234-0192, no=4]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=5]


===== No 내림 차순 정렬 =====
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=5]
User [name=이사람, address=강원도 영울, phone=010-0234-0192, no=4]
User [name=감수왕, address=충북 제천, phone=010-7234-0192, no=3]
User [name=박영희, address=부산 해운대, phone=010-4234-0192, no=2]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=1]


===== Name asc + No desc 정렬 =====
User [name=감수왕, address=충북 제천, phone=010-7234-0192, no=3]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=1]
User [name=고철수, address=경기도 성남시 분당구, phone=010-1234-0192, no=5]
User [name=박영희, address=부산 해운대, phone=010-4234-0192, no=2]
User [name=이사람, address=강원도 영울, phone=010-0234-0192, no=4]


번호 제목 날짜 조회 수
33 [gson]mongodb의 api를 이용하여 데이타를 가져올때 "com.google.gson.stream.MalformedJsonException: Unterminated object at line..." 오류발생시 조치사항 2017.12.11 5086
32 lagom-windows용 build.sbt파일 내용 2017.10.12 466
31 lagom-linux용 build.sbt파일 내용 2017.10.12 1523
30 lagom의 online-auction-java프로젝트 실행시 "Could not find Cassandra contact points, due to: ServiceLocator is not bound" 경고 발생시 조치사항 2017.10.12 510
29 python3.5에서 numpy버젼에 따른 문제점을 조치하는 방법및 pymysql import할때 오류 발생시 조치사항 2017.09.28 767
28 python test.py실행시 "ImportError: No module named pyspark" 혹은 "ImportError: No module named py4j.protocol"등의 오류 발생시 조치사항 2017.07.04 1055
27 [Jsoup]특정페이지를 jsoup을 이용하여 파싱하는 샘플소스 2017.04.18 917
26 [jsoup]Jsoup Tutorial 2017.04.11 408
25 [메모리 덤프파일 분석] 2017.03.31 307
24 [springframework]Caused by: org.mariadb.jdbc.internal.util.dao.QueryException: Could not read resultset: unexpected end of stream, read 0 bytes from 4 오류 발생시 조치사항 2017.01.23 976
23 [tomcat] logrotate를 이용하여 catalina.out로그파일 일별로 로테이션 저장하기 file 2017.01.18 875
22 List<Map<String, String>>형태의 데이타에서 중복제거 하는 방법 2016.12.23 2596
21 Class.forName을 이용한 메서드 호출 샘플소스 2016.12.21 804
20 Collections.sort를 이용한 List<Map<String, String>>형태의 데이타 정렬 소스 2016.12.15 981
» Collections.sort를 이용한 List<User>형태의 데이타 정렬(숫자, 문자에 대해서 각각 asc/desc및 복합정렬) 2016.12.15 675
18 Eclipse실행시 Java was started but returned exit code=1이라는 오류가 발생할때 조치방법 2016.11.07 933
17 java스레드 덤프 분석하기 file 2016.11.03 250
16 mybatis와 spring을 org.apache.commons.dbcp2.BasicDataSource의 DataSource로 연동할때 DB설정(참고) 2016.10.31 1257
15 Caused by: java.sql.SQLNonTransientConnectionException: Could not read resultset: unexpected end of stream, read 0 bytes from 4 오류시 확인/조치할 내용 2016.10.31 4382
14 VisualVM 1.3.9을 이용한 JVM 모니터링 file 2016.10.27 891
위로