도와주세요!! 개발자님들!
안녕하세요. 오랜만에 접속하네요.
질문이 있을때 마다 SIR를 찾게되네요. 전문가분들이 너무 많으셔서요.
메인 검색
select substr(hv_datetime, 12, 2) as Times from hit_visit group by Times
하위 검색
select count(*) as Count from hit_visit where (1) and hv_set = 'Visit' and hv_datetime like '% ".$Row[0]['Times'].":%'
select count(distinct(hv_ip)) as Count from hit_visit where (1) and hv_set = 'Visit' and hv_datetime like '% ".$Row[0]['Times'].":%'
select count(*) as Count from hit_visit where (1) and hv_set = 'Purchase' and hv_datetime like '% ".$Row[0]['Times'].":%'
select count(*) as Count from hit_visit where (1) and hv_set = 'Put' and hv_datetime like '% ".$Row[0]['Times'].":%'
select count(*) as Count from hit_visit where (1) and hv_set = 'Attention' and hv_datetime like '% ".$Row[0]['Times'].":%'
이런 방식으로 불러오고 있습니다.
그런데 이용자가 많아지다보니 속도부분에서 너무 오래 걸리게 되더라구요..
혹시 한번에 처리 할 수 있는 방법은 없을까요?
간단한 예제 부탁드립니다.
그리고 감사합니다.^^
댓글 6개
(select count(*) as Count from hit_visit where (1) and hv_set = 'Visit' and hv_datetime like '% ".$Row[0]['Times'].":%' ) as hit_visit1
(select count(distinct(hv_ip)) as Count from hit_visit where (1) and hv_set = 'Visit' and hv_datetime like '% ".$Row[0]['Times'].":%' ) as hit_visit2
(select count(*) as Count from hit_visit where (1) and hv_set = 'Purchase' and hv_datetime like '% ".$Row[0]['Times'].":%' ) as hit_visit3
(select count(*) as Count from hit_visit where (1) and hv_set = 'Put' and hv_datetime like '% ".$Row[0]['Times'].":%' ) as hit_visit1
(select count(*) as Count from hit_visit where (1) and hv_set = 'Attention' and hv_datetime like '% ".$Row[0]['Times'].":%' ) as hit_visit4
이런식으로 해서
hit_visit1 ~ hit_visit4 까지 한번 에 가지오 올수 있습니다.
그리고 데이터 양이 많아서 속도가 느리면요..조건걸럼에다가 index를 걸어주시면 속도가 훨씬 빨라집니다.
그런데 ㅠㅠ 실행이 안되네요.. ㅠㅠ찡
$Select = "
select
(select count(*) as Count from hit_visit where (1) and hv_set = 'Visit' and hv_datetime like '% 05:%' ) as hit_visit1
(select count(distinct(hv_ip)) as Count from hit_visit where (1) and hv_set = 'Visit' and hv_datetime like '% 05:%' ) as hit_visit2
(select count(*) as Count from hit_visit where (1) and hv_set = 'Purchase' and hv_datetime like '% 05:%' ) as hit_visit3
(select count(*) as Count from hit_visit where (1) and hv_set = 'Put' and hv_datetime like '% 05:%' ) as hit_visit1
(select count(*) as Count from hit_visit where (1) and hv_set = 'Attention' and hv_datetime like '% 05:%' ) as hit_visit4
";
$Query = sql_query($Select);
while($Row = sql_fetch_array($Query)){
print_r($Row);
echo "<br/>";
}
윗 분님의 설명대로
index를 걸어도 도움은 됩니다만
약효는 금방 떨어질듯 합니다.
참고로 count(*) 보다 특정 컬럼 한개 예를들어 select count(no) 와 같이 처리하시는게 속도에 도움이됩니다.
저도 다시 잘 기억하겟습니다. 감사합니다.
게시판 목록
토크
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 3211 | 9년 전 | 1118 | ||
| 3210 |
전갈자리남자
|
9년 전 | 964 | |
| 3209 | 9년 전 | 1252 | ||
| 3208 |
|
9년 전 | 1648 | |
| 3207 |
|
9년 전 | 1711 | |
| 3206 |
PlayPixel
|
9년 전 | 1025 | |
| 3205 | 9년 전 | 1030 | ||
| 3204 | 9년 전 | 1399 | ||
| 3203 |
kiplayer
|
9년 전 | 1806 | |
| 3202 | 9년 전 | 1032 | ||
| 3201 | 9년 전 | 1521 | ||
| 3200 | 9년 전 | 936 | ||
| 3199 | 9년 전 | 1708 | ||
| 3198 | 9년 전 | 1399 | ||
| 3197 | 9년 전 | 1207 | ||
| 3196 | 9년 전 | 1595 | ||
| 3195 |
|
9년 전 | 1097 | |
| 3194 | 9년 전 | 954 | ||
| 3193 |
|
9년 전 | 1021 | |
| 3192 | 9년 전 | 1143 | ||
| 3191 |
|
9년 전 | 861 | |
| 3190 | 9년 전 | 766 | ||
| 3189 |
|
9년 전 | 983 | |
| 3188 |
PASKRAN
|
9년 전 | 852 | |
| 3187 | 9년 전 | 840 | ||
| 3186 |
|
9년 전 | 958 | |
| 3185 | 9년 전 | 947 | ||
| 3184 |
|
9년 전 | 938 | |
| 3183 |
|
9년 전 | 771 | |
| 3182 |
|
9년 전 | 1158 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기