Background Image

FORUM

조회 수 94 추천 수 0 댓글 2
?

단축키

Prev이전 문서

Next다음 문서

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


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Linux 64bit
CUBRID Ver.
9.1
CUBRID TOOL Ver.
10.1
응용 환경(API)
CUBRID 매니저


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------

아래와 같은 테이블(table1) 데이터로부터

year bsns_cd sn ano bno sum
2021 KN07000 1 RRN_0000000324 RMN_0000000493 464000000
2021 KN07000 1 RRN_0000000324 RMN_0000000493 464000000
2021 KN07000 1 RRN_0000000324 RMN_0000000528 467000000
2021 KN07000 1 RRN_0000000324 RMN_0000000528 467000000
2021 KN07000 1 RRN_0000000324 RMN_0000000563 467000000
2021 KN07000 1 RRN_0000000324 RMN_0000000563 467000000
2021 KN07000 1 RRN_0000000324 RMN_0000000567 467000000
2021 KN07000 1 RRN_0000000324 RMN_0000000567 467000000
2021 KN07000 1 RRN_0000000324 RMN_0000000489 575000000
2021 KN07000 1 RRN_0000000324 RMN_0000000489 575000000
2021 KN07000 1 RRN_0000000325 RMN_0000000578 468000000
2021 KN07000 1 RRN_0000000325 RMN_0000000578 468000000
2021 KN07000 2 RRN_0000000308 RMN_0000000554 135400000
2021 KN08000 1 RRN_0000000299 RMN_0000000409 354000000

아래표와 같이 year, bsns_cd, sn을 기준으로 ano, bno에 대한 asc order를 유지한 상태로 ano, sum에 따른 일련번호(sn2)를 부여하려고 합니다.

year bsns_cd sn ano bno sum sn2
2021 KN07000 1 RRN_0000000324 RMN_0000000489 575000000 1
2021 KN07000 1 RRN_0000000324 RMN_0000000489 575000000 1
2021 KN07000 1 RRN_0000000324 RMN_0000000493 464000000 2
2021 KN07000 1 RRN_0000000324 RMN_0000000493 464000000 2
2021 KN07000 1 RRN_0000000324 RMN_0000000528 467000000 3
2021 KN07000 1 RRN_0000000324 RMN_0000000528 467000000 3
2021 KN07000 1 RRN_0000000324 RMN_0000000563 467000000 3
2021 KN07000 1 RRN_0000000324 RMN_0000000563 467000000 3
2021 KN07000 1 RRN_0000000324 RMN_0000000567 467000000 3
2021 KN07000 1 RRN_0000000324 RMN_0000000567 467000000 3
2021 KN07000 1 RRN_0000000325 RMN_0000000578 468000000 4
2021 KN07000 1 RRN_0000000325 RMN_0000000578 468000000 4
2021 KN07000 2 RRN_0000000308 RMN_0000000554 135400000 1
2021 KN08000 1 RRN_0000000299 RMN_0000000409 354000000 1

 

그런데 DENSE_RANK 함수가 용도에 맞다고 생각하여

SELECT year, bsns_cd, sn, ano, bno, sum, DENSE_RANK() OVER (PARTITION BY year, bsns_cd, sn ORDER BY ano, sum) AS sn2 
FROM table1;
이 쿼리를 실행하면 sum=464000000인 항목(빨간색)이 sn2=1이 되고 sum=467000000인 항목(파란색)이 sn2=2가 되어서 bno의 순서가 맞지 않게 됩니다.

 

위와 같은 결과를 출력하려면 쿼리에서 집함함수와 정렬 관계를 어떻게 작성해야 할지 문의드립니다.(큐브리드 버전 9.1, 매니저 버전 10.1)

 

  • ?
    엄기호 2023.01.31 12:57

    큐브리드를 이용해주셔서 감사합니다.

    위 내용대로 테이블과 데이터를 만들어 테스트를 해 보았습니다.
    질의문에 대한 결과 출력
    csql> SELECT [year], bsns_cd, sn, ano, bno, [sum]
    , DENSE_RANK() OVER (PARTITION BY [year], bsns_cd, sn ORDER BY ano, [sum]) AS sn2
    FROM table1;
    === <Result of SELECT Command in Line 1> ===
    year bsns_cd sn ano bno sum sn2
    ============================================================================
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000493' 464000000 1
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000493' 464000000 1
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000528' 467000000 2
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000528' 467000000 2
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000563' 467000000 2
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000563' 467000000 2
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000567' 467000000 2
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000567' 467000000 2
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000489' 575000000 3
    '2021' 'KN07000' 1 'RRN_0000000324' 'RMN_0000000489' 575000000 3
    '2021' 'KN07000' 1 'RRN_0000000325' 'RMN_0000000578' 468000000 4
    '2021' 'KN07000' 1 'RRN_0000000325' 'RMN_0000000578' 468000000 4
    '2021' 'KN07000' 2 'RRN_0000000308' 'RMN_0000000554' 135400000 1
    '2021' 'KN08000' 1 'RRN_0000000299' 'RMN_0000000409' 354000000 1

    14 rows selected. (0.004350 sec) Committed. (0.000010 sec)

    1 command(s) successfully processed.
    csql>
    ============================================================================
    ==> "464000000" 의 값이 sn2=1 이며 위에서 작성된 순서에 맞게 출력 됩니다.

    실제 CUBRID 엔진 버전을 알려주시면 감사하겠습니다.
    버전 확인 질의문 : select version();

  • ?
    플레이어블 2023.02.02 14:25
    버전 확인 : 9.1.0.0218
    제가 처음에 올린 쿼리로 실행하면 출력 결과가 올려주신 대로 나오게 됩니다.
    그런데 제가 문의드린 내용은 출력 결과가 원문의 2번째 표처럼 나오도록 하는 것입니다.
    (동일한 ano에 대해서 동일한 sum끼리 sn2를 부여하되 정렬 순서는 year > bsns_cd > sn > ano > bno 순서로 정렬)

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 48
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3814 CUBRID 11.2 & CUBRID Aadmin 11.1 오류 문의 2 file 붉은구름 2023.03.08 135
3813 도커에서 설치시 접속 문의드립니다. 1 핫산 2023.03.07 396
3812 특수문자 포함 LIKE검색 1 SEO 2023.03.06 155
3811 cubrid admin 질문 드립니다. 3 file 초코초코초 2023.03.06 119
3810 plugin방식 호출 1 file 네오랜덤 2023.03.04 142
3809 서브쿼리시 질문드립니다. 2 dev123123 2023.02.28 151
3808 Cubrid DB 의 sqoop 사용시 옵션 문의 1 망고라떼 2023.02.28 100
3807 큐브리드 통계정보 관련 문의드립니다. 1 초코초코초 2023.02.26 119
3806 cubrid 매니저 패스워드 공용으로 사용하는건가요?? 2 학아 2023.02.24 178
3805 list 합수의 결과를 varchar 컬럼에 insert 시 오류 문의 1 file 플레이어블 2023.02.24 126
3804 LOG 설정 관련 질문입니다. 1 jemin 2023.02.23 90
3803 큐브리드 unload 문의드립니다. 5 초코초코초 2023.02.22 226
3802 Mac OS 에서 Cubrid Manager 실행이 안됩니다. 1 file 엘L 2023.02.20 330
3801 쿼리 플랜 cardinality, cost 이상 1 parknnna 2023.02.16 184
3800 조건절 in 에 들어가는 순서대로 뽑고 싶습니다. 1 구르마도리 2023.02.15 92
3799 Cubrid 11.2 접속 문제. 1 엘L 2023.02.15 137
3798 cubrid 매니저 백업 자동화 추가 비활성 1 제리리 2023.02.15 125
3797 Mac OS 큐브리드 매니저 설치 문제 6 file DJ 2023.02.13 323
3796 (함수)펑션 오류 확인부탁드립니다. 1 초코초코초 2023.02.10 102
3795 필드 추가시 빨랐던 select문 느려지는 이유 3 나라디 2023.02.10 127
Board Pagination Prev 1 ... 5 6 7 8 9 10 11 12 13 14 ... 200 Next
/ 200

Contact Cubrid

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