메뉴 건너뛰기

프로그램언어

2015.04.14 10:27

검색어 처리 루틴

조회 수 21641 추천 수 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
번호 제목 날짜 조회 수
280 PHP 파일 다루기 2015.04.14 23347
279 DB 내용을 화면에 출력(이중 for 문) 2015.04.14 22027
278 한글자르기 substr 2015.04.14 26190
277 전화번호에 하이픈(-) 넣기 2015.04.14 27583
276 PHP switch 문 file 2015.04.14 21930
275 array (배열) 2015.04.14 25850
274 PHP continue 문 file 2015.04.14 21805
273 PHP 삼항연산자 ? file 2015.04.14 23838
272 파일 삭제 2015.04.14 26153
» 검색어 처리 루틴 2015.04.14 21641
270 PHP error 메시지 출력 file 2015.04.14 21815
269 디렉토리내 특정 확장자를 가진 파일 전부 삭제 file 2015.04.14 26419
268 PHP에서 CSV 파일 export file 2016.04.22 23176
267 HTTP Protocol의 data method - GET / POST 2016.04.22 21496
266 RSSReader Class 제작 및 Reader 만들기 file 2016.08.22 21919
265 템플릿 관련 정보 2016.08.22 21693
264 환경변수 HTTP_USER_AGENT를 이용해서 스마트 기기 분류하기 2016.09.21 26863
263 $_SERVER 환경변수 2016.09.21 34134
262 PHP Mcrypt 라이브러리를 활용한 암호화 시스템 2016.12.22 20816
261 시간관련함수 2016.12.22 18207
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved