Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Linux
CUBRID Ver.
10.1.3.7765
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)


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


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

데이터가 다른 DB 가 두 개 있습니다. 


CUBRID 버전은 10.1.3 으로 동일합니다. 


Hibernate 4.3.8-Final 사용중입니다. 


-- 실행한 쿼리 


SELECT count(*) as col_0_0_

FROM discharge discharge0_

CROSS JOIN charge charge1_

CROSS JOIN charge_type chargetype2_

WHERE discharge0_.id=charge1_.id

AND charge1_.charge_type_id=chargetype2_.id

AND chargetype2_.is_media_charge=0

AND discharge0_.discharge_date='2020-9-23 0:0:0.000'

AND discharge0_.proc_branch_id=1;




A DB 에서 실행할 시에는 INDEX 를 올바르게 타고 조회가 됩니다. 

Query Plan:

  NESTED LOOPS (inner join)

    NESTED LOOPS (inner join)

      INDEX SCAN (discharge0_.idx_discharge_01) (key range: discharge0_.discharge_date= ?:1 )

      INDEX SCAN (charge1_.pk_charge) (key range: discharge0_.id=charge1_.id)

    INDEX SCAN (chargetype2_.pk_charge_type) (key range: charge1_.charge_type_id=chargetype2_.id)


  rewritten query: select count(*) from discharge discharge0_ cross join charge charge1_ cross join charge_type chargetype2_ where discharge0_.id=charge1_.id and charge1_.charge_type_id=chargetype2_.id and discharge0_.proc_branch_id= ?:0

 and discharge0_.discharge_date= ?:1  and chargetype2_.is_media_charge= ?:2


Trace Statistics:

  SELECT (time: 0, fetch: 29, ioread: 0)

    SCAN (index: discharge.idx_discharge_01), (btree time: 0, fetch: 6, ioread: 0, readkeys: 1, filteredkeys: 0, rows: 4) (lookup time: 0, rows: 4)

      SCAN (index: charge.pk_charge), (btree time: 0, fetch: 12, ioread: 0, readkeys: 4, filteredkeys: 0, rows: 4) (lookup time: 0, rows: 4)

        SCAN (index: charge_type.pk_charge_type), (btree time: 0, fetch: 8, ioread: 0, readkeys: 4, filteredkeys: 0, rows: 4) (lookup time: 0, rows: 4)


1 row selected. (0.006396 sec) Committed.

1 command(s) successfully processed.




그러나 B DB 에서 실행할 시에는 INDEX 를 타지 않고 조회가 됩니다. 


1 row selected. (142.158127 sec) Committed.


1 command(s) successfully processed.


Trace Statistics:

  SELECT (time: 142150, fetch: 172002917, ioread: 0)

    SCAN (table: charge_type), (heap time: 0, fetch: 5, ioread: 0, readrows: 4, rows: 4)

      SCAN (index: charge.fk_charge_6), (btree time: 7, fetch: 5789, ioread: 0, readkeys: 3, filteredkeys: 0, rows: 5776) (lookup time: 6, rows: 5776)

        SCAN (index: discharge.fk_discharge_2), (btree time: 21134, fetch: 26644688, ioread: 0, readkeys: 5776, filteredkeys: 0, rows: 26598480) (lookup time: 18773, rows: 148)





쿼리에서 생성된 Table 및 PK, FK , INDEX 는 모두 동일한 상황입니다. 


해결할 방법이 있을까요 ? 

 


  • ?
    오명환 2020.12.17 16:56
    해당 테이블의 통계를 재 수집한 후에 다시 한번 확인해보시기 바랍니다.

    통계 수집하는 방법은 매뉴얼(https://www.cubrid.org/manual/ko/10.1/sql/tuning.html)을 참조하시면 됩니다.
    수집하실때 sample을 사용하지 마시고, with fullscan을 사용하셔서 하세요.
  • ?
    Rega 2020.12.21 10:49
    답변 감사드립니다. 통계 재수집후 진행토록 해보겠습니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 34
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3333 데이터 볼륨을 추가 하는 명령어 확인 부탁 드립니다. 7 Philip Park 2020.12.29 246
3332 Cannot cummunicate with broker.. 1 file 진석 2020.12.29 129
3331 샤드 관련 문의 드립니다. 1 레오나르도 2020.12.28 99
3330 WinNGS 통해서 CM 관리모드 사용할때 8001포트 사용하고 있습니다. 1 Philip Park 2020.12.24 1590
3329 시스템 뷰 조회 성능 문의 4 bchlim 2020.12.22 167
3328 마이그레이션 툴킷 관련 질문드립니다. 1 csc0312 2020.12.17 116
» SELECT 시 INDEX 를 타고 안타는 차이점 ? 2 Rega 2020.12.17 396
3326 로그 확인 요청드립니다. 1 file Philip Park 2020.12.17 93
3325 Cubrid 모니터링 1 세모옹자 2020.12.14 137
3324 쿼리 로그를 남기는 트리거 작성 1 도여도여도여도여 2020.12.12 163
3323 Openssl 취약점 패치 문의 2 아스페리타스 2020.12.11 150
3322 stored procedure 질문입니다. 3 거북왕 2020.12.11 184
3321 ha 구성시 warning summary 'SP' 질문있어요 2 덴드로비움 2020.12.10 85
3320 Cubrid Manager 멀티접속 2 세모옹자 2020.12.08 195
3319 HA 절체 테스트를 위해 master db 서비스를 stop 했을 때 exception 발생 됨 1 푸르른하늘 2020.12.07 257
3318 Cubrid 지원 CPU문의 1 B.redsun 2020.12.01 125
3317 cubrid broker의 job_queue 가 궁금합니다 2 kubrid 2020.11.30 192
3316 인덱스를 엉뚱한 걸 타고 있습니다??! 9 file Philip Park 2020.11.26 299
3315 show heap 오류.. 5 밤톨이 2020.11.25 159
3314 데이터 업로드 관련 문의입니다. 2 왕왕초보왕왕 2020.11.25 96
Board Pagination Prev 1 ... 29 30 31 32 33 34 35 36 37 38 ... 200 Next
/ 200

Contact Cubrid

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