메뉴 건너뛰기

프로그램언어

2015.04.14 19:27

검색어 처리 루틴

조회 수 20833 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

PHP 에서 검색어를 여러개 입력하여 AND 조건이나 OR 조건을 검색해야 하는 경우가 있다.


검색어가 여러개면 보통 이렇게 검색어 처리를 하기 쉽다.

$keystr = explode(" ", $keyword);

$sqlque .= " and (eng LIKE '%".trim($keystr[0])."%')";


if($keystr[1]) {
    $sqlque .= " and (eng LIKE '%".trim($keystr[1])."%')";
}
if($keystr[2]) {
    $sqlque .= " and (eng LIKE '%".trim($keystr[2])."%')";
}
if($keystr[3]) {
    $sqlque .= " and (eng LIKE '%".trim($keystr[3])."%')";
}
if($keystr[4]) {
    $sqlque .= " and (eng LIKE '%".trim($keystr[4])."%')";
}
if($keystr[5]) {
    $sqlque .= " and (eng LIKE '%".trim($keystr[5])."%')";
}


이걸 좀더 깔끔하기 처리하는 방법은 아래처럼 array 와 join 함수를 이용하는 것이다.

$keystr = explode(" ", $keyword);
$exp_query = array();
for ($i = 0; $i < count($keystr) ; $i++) {
    array_push($exp_query, "eng LIKE '%".$keystr[$i]."%'" );
}
if(count($exp_query) > 0){
    $sqlque .= " and ( ";
    $sqlque .= join(" and ", $exp_query);
    $sqlque .= " ) ";
}
echo $sqlque; // 쿼리문이 정상인지 확인


List of Articles
번호 제목 날짜 조회 수
80 시간관련함수 2016.12.23 17395
79 PHP Mcrypt 라이브러리를 활용한 암호화 시스템 2016.12.22 20036
78 $_SERVER 환경변수 2016.09.21 33312
77 환경변수 HTTP_USER_AGENT를 이용해서 스마트 기기 분류하기 2016.09.21 26043
76 템플릿 관련 정보 2016.08.22 20989
75 RSSReader Class 제작 및 Reader 만들기 file 2016.08.22 21114
74 HTTP Protocol의 data method - GET / POST 2016.04.22 20707
73 PHP에서 CSV 파일 export file 2016.04.22 22428
72 디렉토리내 특정 확장자를 가진 파일 전부 삭제 file 2015.04.14 25596
71 PHP error 메시지 출력 file 2015.04.14 21010
» 검색어 처리 루틴 2015.04.14 20833
69 파일 삭제 2015.04.14 25410
68 PHP 삼항연산자 ? file 2015.04.14 23026
67 PHP continue 문 file 2015.04.14 21180
66 array (배열) 2015.04.14 24974
65 PHP switch 문 file 2015.04.14 21064
64 전화번호에 하이픈(-) 넣기 2015.04.14 26699
63 한글자르기 substr 2015.04.14 25324
62 DB 내용을 화면에 출력(이중 for 문) 2015.04.14 21313
61 PHP 파일 다루기 2015.04.14 22474
Board Pagination Prev 1 ... 8 9 10 11 12 13 14 15 16 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved