Background Image
조회 수 13905 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

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

게시판 응용의 경우 해당 게시물에 대해 조회할 때 마다 조회수를 업데이트 시켜주고, 조회수를 역순 정렬하여 조회수가 높은 게시물부터 보여 주는 경우가 있다.

이러한 경우 게시물 수가 많으면 많을 수록 조회수 컬럼으로 정렬하기 위한 비용이 크게 발생하여 좋은 성능을 기대하기 어렵다.

이때 조회수 컬럼에 인덱스를 걸어 주면 이미 정렬된 인덱스에 대한 스캔으로 인해 전체 데이터에 대한 정렬작업이 생략되어 빠른 처리 결과를 나타낸다.

하지만 조회수 컬럼의 경우 빈번하게 업데이트가 발생함에 따라 Lock을 잡기위한 경합이 늘어날 가능성이 매우 높다.

이러한 경우 인덱스를 조회수만으로 단일 컬럼 인덱스를 생성하지 않고, unique 또는 unique에 가까운 컬럼을 조회수와 함께 멀티 컬럼 인덱스를 생성하게 되면 lock 경합에 의한 지연이 거의 발생하지 않게 된다.
추가 컬럼은 조회수 컬럼 뒤에 생성하여야 한다.

예제

create table bbs(

seq int primary key,

...

view_cnt int

...

)


create index on bbs(view_cnt desc, seq);

  • ?
    오명환 2017.03.08 00:59

    큐브리드의 인덱스 구조에 대한 설명입니다.

    http://d2.naver.com/helloworld/1043622

    함께 읽어보시면 도움이 될 것 같네요.


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
199 CUBRID 매니저 CUBRID에서 여러개의 질의 결과 확인하는 방법 file seongjoon 2010.01.02 14440
198 질의작성 CUBRID에서 응용프로그램 쿼리 binding 구문이 있을 경우 plan의 차이 cubebridge 2009.11.06 15700
197 응용개발 CUBRID에서 제약조건(PK,FK,UNIQUE),index 설정 시 주의 사항 cubebridge 2009.11.26 18886
196 운영관리 CUBRID에서의 BLOB/CLOB 사용시 백업 및 복구에 대한 주의 점 cubebridge 2012.09.18 33157
195 운영관리 CUBRID에서의 출력 메시지 한글로 변경 방법. file seongjoon 2010.03.01 12440
194 CUBRID 매니저 CUBRID와 CUBRID Web Manager설치, 그리고 XE의설치 및 연동까지 file cubebridge 2012.11.13 18099
193 응용개발 CUBRID와 Oracle에서의 ''(공백)의 차이 비교 cubebridge 2010.10.01 28583
192 마이그레이션 CUBRID와 Oracle의 NULL과 '' (empty string)의 처리 차이점 1 권호일 2015.12.29 15418
191 응용개발 CUBRID의 Statement pooling기능 cubebridge 2009.11.06 16944
190 응용개발 CUBRID의 날짜형 타입을 java의 날짜형 타입에 할당할 때의 값 비교. file seongjoon 2009.12.16 20420
189 기타 CUBRID의OLE DB 드라이버 설치 방법. file seongjoon 2009.08.24 16263
188 운영관리 CUBRID제거 절차 janus 2009.12.12 15888
187 질의작성 Cubrid는 어떤 쿼리를 동일한 쿼리로 판단할까? 이상신 2015.12.30 4010
186 CUBRID 매니저 Database(db이름) is running is standalone mode 오류가 뜰 경우 file 시난 2009.04.29 28488
185 기타 EVALUATE method 수행시 주의해야 할 점 웁쓰 2009.12.31 12875
184 질의작성 FOR UPDATE 정만영 2016.01.27 5990
183 운영관리 HP-ux에서 jvm loading이 실패하는 경우 조치 사항 admin 2008.11.21 22432
182 질의작성 INSERT수행 시, 현재날짜,현재시각으로 자동 입력하는 방법 주현 2015.07.08 25201
181 질의작성 INSTR함수 사용하기 엄기호 2016.06.29 9260
180 질의작성 Integer 컬럼의 결과에 + or – 연산을 할 때 주의해야 할 점 웁쓰 2009.12.31 13493
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 14 Next
/ 14

Contact Cubrid

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