Background Image

FORUM

2020.10.08 13:42

서브쿼리의 max값

조회 수 298 추천 수 0 댓글 3
?

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
window10 64bit
CUBRID Ver.
10.2
CUBRID TOOL Ver.
10.2
응용 환경(API)
java

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


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


메인테이블에 이력테이블의 맨 마지막 정보를 가져오려고 서브쿼리를 걸고 있는데 속도가 굉장히 느립니다


서브쿼리를 하지 않고 바로 조인을 걸면 좋겠지만 이력의 맨 마지막 최근값을 가지고 오려면 max로 서브 쿼리를 사용해야 합니다


이렇게 max값을 가지고와야 하는 부분은 어떻게해야 빨라질수 있을까요??


select count(*)

from  tbl_a a

        left outer join (select seq, max(seqb) seqb

                           from tbl_b

                           group by seq

        ) mx on a.seq = mx.seq

  • ?
    민순 2020.10.12 16:58
    어떤 부분이 오래 걸리는지 확인 가능할까요?

    max 값을 가져오는

    Q1 : select seq, max(seqb) seqb

    from tbl_b

    group by seq

    Q1번 쿼리가 느린지, 아니면 Q1의 결과 테이블과 tbl_a 테이블이 조인하는 쿼리가 오래 걸리는 지 확인 부탁드립니다.
  • ?
    하하 2020.10.13 09:24
    select count(*) fromt tbl_a 이 부분은 0.0초 나오며
    select seq, max(seqb) seqb from tbl_b group by seq 이 부분도 0.1초로 나옵니다
    전체로 하면 68초 정도 나옵니다
  • ?
    박세훈 2020.10.13 11:01
    1. USE_MERGE 힌트를 사용하여 sort merge join을 사용해 보세요.
    https://www.cubrid.org/manual/ko/10.2/sql/tuning.html#sql

    2. 위 쿼리는 1:1 관계이고 left outer join이기 때문에 subquery mx와 join이 필요없는 형태입니다. join을 제거하는 것도 방법입니다.
    3. count 쿼리가 아니고 조회 값을 가져오는 형태라면 select 절에 subquery를 넣는 scalar subquery도 고려해보세요.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 1328
3462 cubrid auto increament 동시성 4 dodev 2021.07.21 24
3461 ALTER 로 PK 여러 개 지정하고싶습니다 4 사탕구름 2021.07.21 23
3460 날짜 형식 변환 질문 1 큐브리드헬프미 2021.07.20 16
3459 트랜잭션 격리 수준 관련한 에러 메시지 6 file gjgj 2021.07.15 57
3458 on duplicate key update values 사용 방법 질문 4 dodev 2021.07.14 32
3457 큐브리드 테이블 excel 출력관련 1 beee 2021.07.12 28
3456 cubrid 에서 tibero로 마이그레이션을 하고 싶은데 CMT툴에서 지원이 가능한지요? 1 덴드로비움 2021.07.12 26
3455 질의자동화 등록 오류 관련 문의 2 file ots21 2021.07.07 26
3454 SYS_TIME 출력 시 문의사항 1 오렌지 2021.07.01 32
3453 INSERT 문 VALUES 에 SELECT구문 문의 2 cubrid초보 2021.07.01 47
3452 맥북에서 큐브리드 매니저 실행 시 Failed to create the Java Virtual Machine.에러 3 ysh 2021.06.30 35
3451 oracle_style_empty_string=yes 설정 문의 5 cubrid초보 2021.06.29 49
3450 큐브리드 컬럼 길이 문의 6 큐브리드궁금 2021.06.29 62
3449 날짜 사이 데이터 구하기 2 cubrid초보 2021.06.29 35
3448 Log 문의 2 jungsin 2021.06.25 37
3447 JAVA VM is not running 오류 2 jungsin 2021.06.25 35
3446 cubrid가 실행이 안됩니다. 4 file 푸른호랑이 2021.06.23 59
3445 큐브리드의 테이블 생성일시, 수정일시 등을 확인 할 수 있는 쿼리를 알고싶습니다. 1 풍류인생 2021.06.22 48
3444 서버에서 broker 에러가 발생합니다. 1 동구리 2021.06.21 66
3443 iso8601을 cast하려면 어떻게 해야되나요? 1 자등명법등명 2021.06.21 33
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 174 Next
/ 174

Contact Cubrid

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