메뉴 건너뛰기

프로그램언어

2015.04.14 19:27

검색어 처리 루틴

조회 수 20834 추천 수 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 22474
279 DB 내용을 화면에 출력(이중 for 문) 2015.04.14 21313
278 한글자르기 substr 2015.04.14 25324
277 전화번호에 하이픈(-) 넣기 2015.04.14 26699
276 PHP switch 문 file 2015.04.14 21064
275 array (배열) 2015.04.14 24974
274 PHP continue 문 file 2015.04.14 21181
273 PHP 삼항연산자 ? file 2015.04.14 23026
272 파일 삭제 2015.04.14 25410
» 검색어 처리 루틴 2015.04.14 20834
270 PHP error 메시지 출력 file 2015.04.14 21010
269 디렉토리내 특정 확장자를 가진 파일 전부 삭제 file 2015.04.14 25596
268 PHP에서 CSV 파일 export file 2016.04.22 22428
267 HTTP Protocol의 data method - GET / POST 2016.04.22 20707
266 RSSReader Class 제작 및 Reader 만들기 file 2016.08.22 21114
265 템플릿 관련 정보 2016.08.22 20989
264 환경변수 HTTP_USER_AGENT를 이용해서 스마트 기기 분류하기 2016.09.21 26043
263 $_SERVER 환경변수 2016.09.21 33312
262 PHP Mcrypt 라이브러리를 활용한 암호화 시스템 2016.12.22 20036
261 시간관련함수 2016.12.23 17395
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved