게시판 테이블을 분리하여 속도를 높였습니다.
http://tong2.sir.co.kr/bbs/board.php?bo_table=cm_free&sca=&sfl=wr_comment_content&stx=%EA%B7%B8%EB%88%84%EB%B3%B4%EB%93%9C+%EC%8A%A4%ED%82%A8&sop=and&page=11&page=1
1. 원글(제목+내용)과 코멘트를 분리하였습니다.
2. FULLTEXT 사용으로 검색 속도를 높였습니다.
3. 구간 검색을 없앴고 전체게시물에서 검색하여 원하는 게시물을 빨리 얻을 수 있습니다.
단점. 제목+내용으로 코멘트를 한번에 검색하지 못합니다.
댓글 11개
14년 전
속도차가 눈에 보입니다.
14년 전
위의 링크 에러 출력 됩니다...ㅜㅜ
select SQL_NO_CACHE count(distinct wr_parent) as cnt from `g4_write_cm_free.comment` where (1) and match(wr_fulltext) against('+그누보드* +스킨*' in boolean mode)
1146 : Table 'sir.g4_write_cm_free.comment' doesn't exist
error file : /bbs/board.php
select SQL_NO_CACHE count(distinct wr_parent) as cnt from `g4_write_cm_free.comment` where (1) and match(wr_fulltext) against('+그누보드* +스킨*' in boolean mode)
1146 : Table 'sir.g4_write_cm_free.comment' doesn't exist
error file : /bbs/board.php
14년 전
아직 검색 속도가 만족할만한 수준이 아닙니다.
여러가지 테스트 중에 있어 에러가 발생할수 있습니다.
여러가지 테스트 중에 있어 에러가 발생할수 있습니다.
14년 전
자유게시판의 459,972 건을 별도의 키파일에 두글자 이상을 집어 넣은 결과
CREATE TABLE IF NOT EXISTS `g4_write_cm_free.key` (
`wk_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`wr_parent` int(11) NOT NULL,
`wr_num` int(11) NOT NULL,
`wr_reply` varchar(10) NOT NULL,
`wk_key` varchar(30) NOT NULL,
PRIMARY KEY (`wk_id`),
KEY `wk_key` (`wk_key`)
) ENGINE=MyISAM ;
데이터와 인덱스를 합쳐 732.7MB 라는 용량이 추가로 생겼습니다.
빠른 검색 속도를 희망하였으나 결과는 좋지 않았습니다.
행(레코드) 보기 0 - 29 (183,035 합계, 질의 실행시간 0.9045 초)
SELECT SQL_NO_CACHE wr_parent
FROM `g4_write_cm_free.key`
WHERE wk_key LIKE '가%'
ORDER BY wr_num, wr_reply
CREATE TABLE IF NOT EXISTS `g4_write_cm_free.key` (
`wk_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`wr_parent` int(11) NOT NULL,
`wr_num` int(11) NOT NULL,
`wr_reply` varchar(10) NOT NULL,
`wk_key` varchar(30) NOT NULL,
PRIMARY KEY (`wk_id`),
KEY `wk_key` (`wk_key`)
) ENGINE=MyISAM ;
데이터와 인덱스를 합쳐 732.7MB 라는 용량이 추가로 생겼습니다.
빠른 검색 속도를 희망하였으나 결과는 좋지 않았습니다.
행(레코드) 보기 0 - 29 (183,035 합계, 질의 실행시간 0.9045 초)
SELECT SQL_NO_CACHE wr_parent
FROM `g4_write_cm_free.key`
WHERE wk_key LIKE '가%'
ORDER BY wr_num, wr_reply
14년 전
행(레코드) 보기 0 - 29 (35,060 합계, 질의 실행시간 1.7297 초)
SELECT SQL_NO_CACHE DISTINCT wr_parent
FROM `g4_write_cm_free.comment`
WHERE MATCH (
wr_fulltext
)
AGAINST (
'+가*'
IN boolean
MODE
)
ORDER BY wr_num, wr_reply
위 쿼리는 FULLTEXT 검색시간이 더 늦어 아쉬웠으나...
SELECT SQL_NO_CACHE DISTINCT wr_parent
FROM `g4_write_cm_free.comment`
WHERE MATCH (
wr_fulltext
)
AGAINST (
'+가*'
IN boolean
MODE
)
ORDER BY wr_num, wr_reply
위 쿼리는 FULLTEXT 검색시간이 더 늦어 아쉬웠으나...
14년 전
행(레코드) 보기 0 - 29 (5,371 합계, 질의 실행시간 1.4699 초)
SELECT SQL_NO_CACHE distinct wr_parent FROM `g4_write_cm_free.comment` WHERE match(wr_fulltext) against('그누보드* 스킨*' in boolean mode) order by wr_num, wr_reply;
행(레코드) 보기 0 - 29 (10,020 합계, 질의 실행시간 0.1329 초)
SELECT SQL_NO_CAcHE distinct wr_parent FROM `g4_write_cm_free.key` WHERE wk_key like '그누보드%' or wk_key like '스킨%' order by wr_num, wr_reply
OR 검색의 경우 FULLTEXT 속도가 늦었으나...
별도의 키를 잡은 경우는 AND 검색이 어려운 점이 있어 FULLTEXT 검색을 사용하기로 하였습니다.
4글자를 검색하는 경우는 FULLTEXT 가 약간 더 빨랐으나 우열을 가리기 힘들었습니다.
FULLTEXT 를 사용하는 이유는
별도의 역인덱스 테이블을 잡을 필요가 없으며,
데이터와 인덱스의 용량을 줄이며, AND 검색을 가능하게 하는데 있습니다.
SELECT SQL_NO_CACHE distinct wr_parent FROM `g4_write_cm_free.comment` WHERE match(wr_fulltext) against('그누보드* 스킨*' in boolean mode) order by wr_num, wr_reply;
행(레코드) 보기 0 - 29 (10,020 합계, 질의 실행시간 0.1329 초)
SELECT SQL_NO_CAcHE distinct wr_parent FROM `g4_write_cm_free.key` WHERE wk_key like '그누보드%' or wk_key like '스킨%' order by wr_num, wr_reply
OR 검색의 경우 FULLTEXT 속도가 늦었으나...
별도의 키를 잡은 경우는 AND 검색이 어려운 점이 있어 FULLTEXT 검색을 사용하기로 하였습니다.
4글자를 검색하는 경우는 FULLTEXT 가 약간 더 빨랐으나 우열을 가리기 힘들었습니다.
FULLTEXT 를 사용하는 이유는
별도의 역인덱스 테이블을 잡을 필요가 없으며,
데이터와 인덱스의 용량을 줄이며, AND 검색을 가능하게 하는데 있습니다.
14년 전
수고하시네요 *^^*
14년 전
자 이제 빛의 속도를 보여주세요
14년 전
눈 앞에 보고 계시면서 그런 말씀하시면 ... ㅠㅠ
Black
14년 전
관리자님.... 수고가 많으시구요...
현재는 테이블을 한개를 쓰는 것으로 아는데..
코멘트 테이블을 따로 분리를 했다니 여러모로 기대가 됩니다.
그러면 분리된 형태의 전혀 다른 새로운 버전이 출시되는 것인지요?
아니면 패치나 업그레이드 형태로 진행이 되는건가요?
현재는 테이블을 한개를 쓰는 것으로 아는데..
코멘트 테이블을 따로 분리를 했다니 여러모로 기대가 됩니다.
그러면 분리된 형태의 전혀 다른 새로운 버전이 출시되는 것인지요?
아니면 패치나 업그레이드 형태로 진행이 되는건가요?
14년 전
패치나 업그레이드 형태가 아니라 SIR에서 사용할 용도입니다.
좋은 결과가 나온다면 차후에 반영이 될수는 있습니다.
그렇지만 당장은 반영이 어렵습니다.
좋은 결과가 나온다면 차후에 반영이 될수는 있습니다.
그렇지만 당장은 반영이 어렵습니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 8265 | |
| 20403 | |
| 20402 | |
| 20401 | |
| 20400 |
웹서버
서버 동시접속자 설정 변경하기
|
| 8259 | |
| 20399 | |
| 20398 | |
| 8255 | |
| 8249 | |
| 8246 | |
| 8242 | |
| 20396 | |
| 8240 | |
| 20395 | |
| 20394 |
MySQL
테이블 복사 쿼리
|
| 31033 | |
| 28385 | |
| 20393 |
PHP
현재 접속중인 사용자 나타내기
|
| 28380 | |
| 20392 |
MySQL
mysql select 후 update 하기
|
| 28377 | |
| 20391 | |
| 20390 |
PHP
한글문자열 자르는 법 입니다.
|
| 20389 | |
| 20388 | |
| 20387 |
PHP
이메일주소 검사하기 입니다.
|
| 20386 | |
| 20385 | |
| 20384 |
node.js
Node js 게시판 프로젝트 소개합니다.
|
| 20383 |
PHP
pc 모바일 체크
1
|
| 20382 |
PHP
계정 사용량(용량) 확인
|
| 8238 | |
| 20380 | |
| 20379 |
MySQL
소수점 반올림 버림
|
| 28376 | |
| 28372 | |
| 20378 | |
| 20377 |
PHP
에러 로그파일 생성하기
|
| 8235 | |
| 20375 | |
| 20374 | |
| 20373 |
PHP
후이즈검색 하기 입니다.
|
| 20372 |
PHP
그래프 그리기 입니다.
|
| 20371 |
JavaScript
자바스크립트로 구현한 number_format() 입니다.
|
| 20370 |
JavaScript
금액 관련 숫자를 한글로 변환하기 입니다.
|
| 28370 | |
| 20369 |
PHP
PHP 날짜 계산 관련 함수
|
| 28366 | |
| 20368 |
jQuery
jQuery 1.x와 2.x 버전 동시에 사용하기
|
| 20367 | |
| 20366 | |
| 20365 |
JavaScript
사업자 등록번호 검사하기 입니다.
|
| 20364 | |
| 20363 |
JavaScript
항상 같은곳에 광고창 만들기 입니다.
|
| 20362 |
JavaScript
부메뉴 나오게 하기 입니다.
|
| 20361 |
JavaScript
특정문자 제거하기 입니다.
|
| 20360 |
JavaScript
휴대폰번호 검사 하기 입니다.
|
| 20359 |
JavaScript
이미지 좌우로 이동 갤러리 입니다.
|
| 8231 | |
| 20358 | |
| 20357 |
JavaScript
쉬운 replaceAll 입니다.
|
| 20356 | |
| 20355 | |
| 20354 | |
| 20353 | |
| 20352 |
JavaScript
콤보스타일 메뉴 입니다.
|
| 20351 |
JavaScript
쿠키를 이용한 레이어 공지창 입니다.
|
| 20350 |
JavaScript
효과있는 텍스트 틱커 입니다.
|
| 20349 | |
| 20348 |
PHP
HTTP 인증 하기 입니다.
|
| 20347 |
JavaScript
외부 문서 불러오기 입니다.
|
| 20346 |
JavaScript
지정한 날짜까지 New 이미지를 띄워주기 입니다.
|
| 20345 | |
| 20344 |
JavaScript
메일 주소 검사하기 체크박스 입니다.
|
| 20343 |
JavaScript
무단링크 금지하기 입니다.
|
| 20342 | |
| 20341 |
MySQL
DB백업 및 복원
|
| 20340 |
JavaScript
페이지가 다른 사이트의 프레임에 갇히는 것을 막기 입니다.
|
| 20339 | |
| 20338 | |
| 20337 |
jQuery
input text 대문자만 받는 Jquery
|
| 20336 | |
| 20335 |
JavaScript
이미지 업로드와 미리보기 입니다.
|
| 20334 |
JavaScript
배경음악 랜덤 재생 하기 입니다.
|
| 20333 |
JavaScript
css 지원 여부 확인해서 다른 페이지로 이동하기 입니다.
|
| 20332 |
JavaScript
하부메뉴가 보였다가 숨겨졌다 하는 토글버튼 입니다.
|
| 20331 |
JavaScript
개별 페이지에 인덱스로 거쳐 들어오게 하기 입니다.
|
| 20330 |
JavaScript
랜덤으로 이미지 출력 되기 입니다.
|
| 20329 |
JavaScript
사용자 해상도 알아내기 입니다.
|
| 20328 |
JavaScript
붙여넣기 금지하기 입니다.
|
| 20327 |
MySQL
대소문자 데이터 조회하기
|
| 20326 |
JavaScript
퇴장시 팝업창 한번한 띄우기 입니다.
|
| 20325 | |
| 20324 | |
| 20323 |
JavaScript
시도, 구군, 동 주소 select
|
| 20322 |
MySQL
커리로 DB 테이블 명세서 출력하기
|
| 20321 |
JavaScript
브라우저 해상도 구분없는 절대 x,y 좌표 값 구하기 입니다
|
| 20320 |
PHP
rss 읽어오기 입니다.
|
| 20319 |
JavaScript
자바스크립트로 Ajax 효과내기 입니다.
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기