테스트 사이트 - 개발 중인 베타 버전입니다

검색질문입니다.. 채택완료

humanb2box 6년 전 조회 1,974

https://sir.kr/g5_tip/3003

 

이 글 참고해서 다중검색이 되게 하고 있는데..

 

다중 검색후 페이징도 안되고,, 

 

특히 궁금한 것은

 

한 게시글안 wr_3에 2018-12-13을 wr_4에 2018-12-15를

 

입력하고

 

2018-12-14를 입력해도 해당 게시글이 검색되게 하려면 .. 어디를 고쳐야 하나요?

common.lib.php

 

646번째줄 여기 맞나요? ㅠㅠㅠ

</p>

<p>  switch ($field[$k]) {

                case "mb_id" :

                case "wr_name" :

                    $str .= " $field[$k] = '$s[$i]' ";

                    break;

                case "wr_hit" :

                case "wr_good" :

                case "wr_nogood" :

                    $str .= " $field[$k] >= '$s[$i]' ";

                    break;

                // 번호는 해당 검색어에 -1 을 곱함

                case "wr_num" :

                    $str .= "$field[$k] = ".((-1)*$s[$i]);

                    break;

                case "wr_ip" :

                case "wr_password" :

                    $str .= "1=0"; // 항상 거짓

                    break;

                // LIKE 보다 INSTR 속도가 빠름

                default :

                    if (preg_match("/[a-zA-Z]/", $search_str))

                        $str .= "INSTR(LOWER($field[$k]), LOWER('$search_str'))";

                    else

                        $str .= "INSTR($field[$k], '$search_str')";

                    break;

            }</p>

<p>

댓글을 작성하려면 로그인이 필요합니다.

답변 1개

플라이
6년 전

검색 타입을 추가하셔서 switch case 구분자 추가후 날짜 검색 쿼리를 추가해 주셔야 합니다.

로그인 후 평가할 수 있습니다

답변에 대한 댓글 1개

h
humanb2box
6년 전
인덱스에서
<input type="text" id="datepicker" name="date" value='<?echo $wr_1?>' autocomplete="off" >
ㅇㅣ것넣고

switch 구문에
이렇게 했는데 아무것도 작동되지 않아용..
[code]
for ($k=0; $k<count($field); $k++) { // 필드의 수만큼 다중 필드 검색 가능 (필드1+필드2...)
$str .= $op2;
switch ($field[$k]) {
case "mb_id" :
case "wr_name" :
$str .= " $field[$k] = '$s[$i]' ";
break;
case "wr_hit" :
case "wr_good" :
case "wr_nogood" :
$str .= " $field[$k] >= '$s[$i]' ";
break;
// 번호는 해당 검색어에 -1 을 곱함
case "wr_num" :
$str .= "$field[$k] = ".((-1)*$s[$i]);
break;
case "wr_5" :
case "wr_6" :
$str .= "$field[$k] > ".((-1)*$s[$i]);
break;
case "date":
$str .= "wr_1 <= '$date' and wr_4 >= '$date' ";
break;
// LIKE 보다 INSTR 속도가 빠름
default :
if (preg_match("/[a-zA-Z]/", $search_str))
$str .= "INSTR(LOWER($field[$k]), LOWER('$search_str'))";
else
$str .= "INSTR($field[$k], '$search_str')";
break;
}
[/code]

댓글을 작성하려면 로그인이 필요합니다.

답변을 작성하려면 로그인이 필요합니다.

로그인