>백엔드 개발 >PHP 튜토리얼 >PHP 검색어 기능 구현

PHP 검색어 기능 구현

墨辰丷
墨辰丷원래의
2018-05-30 11:07:073059검색

이 글은 주로 PHP 검색 쿼리 기능의 구현 코드를 소개합니다. 매우 훌륭하고 참고할 만한 가치가 있습니다. 도움이 필요한 친구들이 참고할 수 있습니다.

오늘 문제가 발생했습니다: "검색" 기능을 할 때 쿼리 조건을 입력하세요. 그런 다음 No를 쿼리합니다.

제가 하는 작업은 데이터 테이블 패키지의 내용을 홈페이지에 표시하는 것인데, 홈페이지에 표시되는 내용도 필드 상태=0, 인쇄=0인 데이터를 표시할 수 있어야 한다는 조건이 있습니다. 홈페이지 목록에서

페이지에 '검색' 기능이 있습니다. 조건을 입력하면 해당 조건에 따라 검색이 진행됩니다.

일반 검색의 경우 홈 페이지 표시 목록 메서드 index()에 하나를 지정하면 됩니다.

$map=array();//初始化查询条件
$map=$this->_search();//调用查询方法
$total = $this->Model->where ($map)->count(); //这个主要是用来计算页面显示数据条数的
if ($total == 0) {
$_list = '';
} else {
$_list = $this->Model->where ($map)->limit( $post_data ['first'] . ',' . $post_data ['rows'] )->select();
}

그런 다음 _search():

를 작성하면 됩니다.

protected function _search(){
$map = array ();
$post_data = I ( 'post.' );
if ($post_data ['packageid'] != '') {
$map ['packageid'] = array (
'like',
'%' . $post_data ['packageid'] . '%' 
);
}
return $map;
}

마지막으로, 설정 "검색" 메뉴에서 이 검색 방법을 호출하세요.

그러나 이렇게 할 때 검색하는 동안 필드 상태=0 및 인쇄=0인 데이터에서도 검색해야 합니다.

이 제한 사항을 어디에 두어야할지 고민하고 있습니다. 다양한 시도와 문의 끝에 알게 되었습니다. 아래 빨간색으로 표시된 것처럼 제한 조건을 SQL 문에 직접 추가하면 됩니다. (직접 시도해 보니 아래 파란색 부분에 조건을 계속 추가하다가 실패를 거듭했습니다!)

$map=array();
$map=$this->_search();
$total = $this->Model->where ($map)->where(array('status' =>0,'print_status'=>0))->count();
if ($total == 0) {
$_list = '';
} else {
$_list = $this->Model->where ($map)->where(array('status' =>0,'print_status'=>0))->limit( $post_data ['first'] . ',' . $post_data ['rows'] )->select();
}

위 내용은 이 글의 전체 내용입니다. 모든 분들의 공부에 도움이 되었으면 좋겠습니다. .


관련 권장 사항 : php


php

의 추가 및 라인 브레이크 파일 _put_contents의 연결 방법을 구현하는 방법을 구현합니다. 필드 중 하나를 기준으로 정렬 방법

위 내용은 PHP 검색어 기능 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:PHP 정밀계산 기능다음 기사:PHP 정밀계산 기능