Background Image
조회 수 21711 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

CUBRID 에서 group by 는 대상이 되는 필드에 대하여 group by 에 전부 명시해주어야 하며, 일부 필드만 명시하면 에러가 발생합니다.


예를 들어, board 라는 테이블에 값이 아래와 같이 있는 경우(순번은 그냥 레코드 순서입니다),

순번      bo_table      bo_subject

  1       'table1'      'subject1'

  2       'table1'      'subject2'

  3       'table2'      'subject1'

 

bo_table 'table1' 인 경우 bo_subject 는 서로 다른 두 개의 값을 가집니다.
이 경우 일반적으로 group by 를 하게 되면 질의는 select bo_table,bo_subject from ... group by bo_table,bo_subject 와 같이 대상이 되는 필드가 모드 group by 절에 명시되어야 하며, 그 결과는 아래와 같습니다.

bo_table      bo_subject

'table1'      'subject1'

'table1'      'subject2'

'table2'      'subject1'

 

그런데 원하는 결과가 모든 필드에 대하여 group by 가 아닌 특정 필드에 대하여만 group by 를 수행하고자 한다면, 이는 기본적으로 지원되는 형식의 질의가 아니므로 질의를 조정하여야만 합니다.

 

위의 경우를 예를 든다면, 아래와 같이 bo_table 에 대하여만 group by가 되고 나머지 필드는 그냥 보여지는 형태를 얻고자 하는 경우입니다. 참고로 bo_subject 의 결과는 'subject1'이 나올지 'subject2'가 나올지는 보장할 수 없습니다. , 원 레코드 1번과 2번중 어느 레코드가 결과로 나올지는 알 수 없다는 것입니다

bo_table      bo_subject

'table1'      'subject1'

'table2'      'subject1'

 

질의를 조정하여 bo_table 에 대하여만 group by 가 되는 것과 같은 모양이 나오도록 하였습니다. , 조건을 추가하여 bo_table 이 같은 값들에 대하여는 하나의 결과만 뽑아내도록 sub-query 를 이용하였습니다.

이렇게 하면 결과는 원하는 대로 나올 수가 있지만 sub-query를 사용함으로써, 기본 조건으로 나오는 결과 수만큼의 sub-query가 수행되므로 성능에는 좋지 않은 결과를 가져다 줍니다.

 

select bo_table, bo_subject, bb_datetime

from board a

where bo_id = '1'

and (a.bo_subject, a.bn_datetime)

        = (select b.bo_subject, b.bn_datetime

                from board b

                where b.bo_table = a.bo_table

                  and rownum = 1

        )

group by bo_table, bo_subject, bn_datetime

 

일단 select 절에 사용된 필드는 group by 절에는 반드시 명시하여야 합니다. 중요한 부분은 굵게 표시된 추가적인 where 절의 내용입니다. bo_table 에 대하여만 group by를 하는 것이니 bo_table의 값은 여러 개가 나와도 되지만, 나머지는 한가지의 값만 나와야 하므로, 나머지에 대하여는 하나의 값만 나오도록 rownum=1 인 것에 대하여 검색되어지도록 조건을 추가한 것입니다.

 


  1. 데이터 존재하면 update, 존재하지 않으면 insert 방법(ON DUPLICATE KEY UPDATE)

  2. 예약어를 테이블명이나 컬럼명으로 사용시

  3. CUBRID DB 내의 auto_increment 값을 초기화 하자.

  4. group_concat(문자열 그룹처리) 함수 사용하기

  5. INSERT수행 시, 현재날짜,현재시각으로 자동 입력하는 방법

  6. 중복데이터 제거 방법

  7. 쿼리로 인덱스 정보 확인하기

  8. 컬럼 사이즈 변경 방법

  9. 데이터 값 작은 따옴표(') 넣기

  10. 쿼리로 테이블이 존재하는지 확인하기

  11. pivot() 간략하게 구현하기

  12. 임의의 컬럼을 rownum 으로 업데이트 하기

  13. 문자 코드셋(UTF-8, EUC-KR) 사용시 CUBRID 는?

  14. 테이블 데이터 복사 하기

  15. 테이블 컬럼 변경 및 추가

  16. LIKE 검색에서 INDEX_SCAN사용 하기

  17. group by 사용 방법 및 여러 필드중 하나의 필드에 대하여만 group by 처리 방법

  18. 모든 필드에 하나 이상 중복 값 찾기

  19. MERGE INTO 사용 예제 ( INSERT, UPDATE문을 1개의 쿼리로 실행 )

  20. 오류데이타검증 - 숫자 이외의 데이타 확인하는 방법

Board Pagination Prev 1 2 3 4 Next
/ 4

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales