실무에서 해결한 문제를 정리해 올립니다.
제가 유지보수를 맡게된 사이트에서 답변형 게시판의 문제를 해결하는데 사용한
쿼리입니다. 게시물 수가 9000건을 넘습니다.
게시판 페이지를 가면 6~8초정도 기다려야 첫페이지가 나옵니다.
다음페이지로 이동할 때도 걸리는 시간은 마찬가지입니다.
DBA 와 같이 상의하고 테스트한 결과 중요한 차이점을 발견했습니다.
쿼리하는 컬럼을 지정하느냐 아니면 * 를 써서 모두 가져오느냐가 큰 성능의 차이를
보였습니다. 단순히 order by 가 들어가면 정렬(sorting) 때문에 느려지는 것으로 알고
있었는데 6초 이상 걸리던 쿼리가 단 0.2 초만에 해결되었습니다.
select *
from pm2000_qna order by record_no desc, record_depth
와
select record_number, record_no, record_depth, record_depthno, record_title,
record_writer,
writer_email, to_char(record_date,'yyyy/mm/dd') record_date, read_count
from pm2000_qna order by record_no desc, record_depth
는 큰 차이라는 뜻입니다.
그리고,
효율적인 db접속을 위해서 게시물 몽땅 가져와서 rs.next() 로 돌려서 위치를 찾는 것
보다는 sql에서 게시물 수만큼 가져와서 뿌려주는 것이 나은 점에 대해서는 이 사이트 여러
곳에서 토론되고 있는 줄 압니다.
오라클에서는 rownum 이 있죠. 어거지로 쓰는 것 같지만 어쩔 수 없죠. 머리를 굴리는
수밖에요.
^^; 수고를 좀 덜어드리면 좋겠습니다.
select * from (
select * from (
select record_no, record_depth, record_depthno, record_title, record_writer,
writer_email, to_char(record_date,'yyyy/mm/dd') record_date, read_count
from pm2000_qna order by record_no desc, record_depth
) where rownum <= ? order by rownum desc
) where rownum <= ? order by rownum desc
jsp 에선
pstmt.setInt(1,(pageNo+1)*pageSize); // pageNo는 0부터..
pstmt.setInt(1,pageSize);
로 해주면 됩니다.
일단 sqlplus 에서 테스트 해보십시오.
아주 속이 시원하더군요.
부록으로 mysql 버전입니다.
select record_no, record_depth, record_depthno, record_title, ...
from pm2000_qna order by seq desc limit ?, ?
jsp에선
pstmt.setInt(1,pageNo*pageSize); // pageNo는 0부터..
pstmt.setInt(1,pageSize);
하시면 됩니다.
좋은 하루 되십시오.
----
http://okjsp.pe.kr kenu[이 게시물은 관리자님에 의해 2011-10-31 16:47:36 Oracle에서 이동 됨]
게시글 목록
| 번호 | 제목 |
|---|---|
| 12651 | |
| 12650 |
JavaScript
query 문자열 최대 길이
|
| 12646 |
JavaScript
이미지 슬라이드 소스입니다(Ajax)
3
|
| 141 | |
| 140 | |
| 138 | |
| 137 | |
| 131 | |
| 130 | |
| 25048 | |
| 12644 | |
| 125 | |
| 122 | |
| 12641 | |
| 12635 |
JavaScript
네비게이션 소스
5
|
| 12632 | |
| 29350 | |
| 12629 |
Linux
서버 관리자라면 요런것도~
2
|
| 29349 | |
| 12628 |
JavaScript
테이블,컬럼 comments (정보관리테이블만들기)
|
| 29348 | |
| 12627 |
MySQL
mysql 연결
|
| 12626 | |
| 12623 |
JavaScript
시간별이미지출력 이것좀봐주세요!~~
2
|
| 25047 | |
| 25045 | |
| 25041 | |
| 25040 | |
| 25038 | |
| 25037 | |
| 117 | |
| 25036 | |
| 12620 | |
| 12618 | |
| 12617 | |
| 12614 |
기타
캐쉬백메뉴
2
|
| 12612 |
JavaScript
배열을이용한이동
1
|
| 12608 |
JavaScript
3dMax를이용한메뉴
3
|
| 12606 |
기타
눈동자
1
|
| 12605 |
기타
눈내리는효과
|
| 29347 |
HTML
심장박동효과
|
| 12604 |
JavaScript
곰장어
|
| 12597 | |
| 12595 |
MySQL
MySQL 형변환 함수
1
|
| 12594 |
MySQL
Mysql 백업 팁
|
| 12593 | |
| 12589 | |
| 12585 | |
| 29346 |
HTML
외부 문서 불러오기
|
| 12584 | |
| 12582 | |
| 12581 | |
| 12580 |
JavaScript
윈도우2003 + Apache 를 위한 SSL 보안서버 구축 팁
|
| 12578 |
JavaScript
AJAX 소스제공 사이트들 입니다.
1
|
| 12576 | |
| 29345 | |
| 12575 |
JavaScript
ORACLE_CATALOG
|
| 12574 | |
| 12573 | |
| 29344 |
HTML
오라클 SQL 기본 간단 정리
|
| 115 | |
| 12572 | |
| 12570 | |
| 29343 |
HTML
레이어를 클릭하면 순서가 바뀌는거에요
|
| 29342 |
HTML
셀렉트 박스 내용을 레이어로 표현
|
| 12569 |
JavaScript
다모임 - 플레이어 입니다(wmv)
|
| 12567 |
JavaScript
디렉토리서비스 소스 입니다.
1
|
| 29337 |
JavaScript
구인 구직 사이트 소스에요~
4
|
| 12566 |
JavaScript
설문조사 소스입니다. 참고하세요.
|
| 12564 |
JavaScript
ASP - FSO 객체 정리한 파일입니다. 많은 도움이 될거에요~
1
|
| 112 | |
| 107 | |
| 104 | |
| 101 | |
| 96 | |
| 94 | |
| 93 | |
| 12563 | |
| 12559 | |
| 88 | |
| 85 | |
| 12558 | |
| 29336 | |
| 29333 |
HTML
버튼소리나는메뉴
2
|
| 84 | |
| 29329 |
HTML
초보자를 위한 포토샵 강좌 63
3
|
| 12556 | |
| 29327 |
HTML
초보자를 위한 포토샵 강좌 61
1
|
| 12554 | |
| 12552 | |
| 12549 | |
| 12545 | |
| 12544 | |
| 29325 |
HTML
초보자를 위한 포토샵 강좌 55
1
|
| 12542 | |
| 12541 | |
| 29324 |
HTML
초보자를 위한 포토샵 강좌 52
|
| 12540 |
JavaScript
초보자를 위한 포토샵 강좌 51
|
| 12539 | |
| 12538 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기