찾다
백엔드 개발PHP 튜토리얼PINQ- 데이터 세트 - 측면 검색 쿼리

PINQ- 데이터 세트 - 측면 검색 쿼리 키 테이크 아웃

PHP LINQ 포트 인 PINQ는 MySQL과 함께 측면 검색 기능을 모방하여 강력하고 간단한 접근 방식을 제공하는 데 사용될 수 있습니다. Faceted Search는 제품을 검색하기 위해 사용자 제공 키워드를 가져 와서 일치하는 제품을 반환하고 다양한 브랜드, 가격 범위 및 기능을 기반으로 검색을 미세 조정하는 링크를 제공함으로써 작동합니다. PINQ는 $ 범위로 지정된 단계에서 값 범위별로 그룹화와 같은 필수 측면 검색 기능을 추가하여 데모 응용 프로그램을 확장하는 데 사용될 수 있습니다. PINQ로 구현 된 Faceted Search는 매번 MySQL 서버에서 데이터를 검색하며 캐싱 엔진을 사용하여 피할 수 있습니다. 기본 데모 임에도 불구하고 Faceted Search에 대한 PINQ의 접근 방식은 개선의 충분한 공간을 제공하며 고급 사용 사례를 위해 구축 할 수 있습니다.

1 부에서는 PHP LINQ 포트 인 PINQ의 설치 및 기본 구문을 간단히 다루었습니다. 이 기사에서는 PINQ를 사용하여 MySQL과 함께 측면 검색 기능을 모방하는 방법을 볼 수 있습니다. 우리는이 시리즈에서 Faceted Search의 전체 측면을 다루지 않을 것입니다. 이해 당사자는 Sitepoint 및 기타 인터넷 간행물에 게시 된 관련 기사를 참조 할 수 있습니다.

일반적인 패싯 검색은 웹 사이트에서 이와 같은 작용합니다 :
    사용자는 검색 할 키워드 또는 몇 가지 키워드를 제공합니다. 예를 들어, 설명, 키워드, 카테고리, 태그 등에 "라우터"가 포함 된 제품을 검색하려면 "라우터" 사이트는 기준과 일치하는 제품을 반환합니다 사이트는 검색을 미세 조정하기위한 일부 링크를 제공합니다. 예를 들어, 라우터에는 다른 브랜드가 있으며 가격 범위와 다른 기능이 다를 수 있습니다.
  • 사용자는 제공된 다른 링크를 클릭하여 결과를 더 스크리닝 할 수 있으며 결국보다 사용자 정의 된 결과 세트를 얻을 수 있습니다.
  • Faceted Search는 매우 인기 있고 강력하며 거의 모든 전자 상거래 사이트에서 경험할 수 있습니다.
  • 불행히도 Faceted Search는 아직 MySQL이 제공하는 내장 기능이 아닙니다. MySQL을 사용하고 있지만 사용자에게 그러한 기능을 제공하려면 어떻게해야합니까? PINQ를 사용하면 다른 DB 엔진을 사용할 때와 같이이를 달성하기위한 똑같이 강력하고 간단한 접근 방식이 있음을 알 수 있습니다. 파트 1 데모 확장 참고 :이 부분의 모든 코드와 Part 1 데모는 repo에서 찾을 수 있습니다. 이 기사에서는 1 부에서 보여준 데모를 확장하고 몇 가지 필수 측면 검색 기능을 추가합니다. <li> <with> 다음 몇 줄을 추가하여 index.php로 시작하겠습니다. </with> </li> <two> 우리는 데모 애플리케이션 (Silex 사용)에서 두 개의 경로를 더 만들었습니다. <li><is> 첫 번째 경로는 첫 번째 검색 동작과 일치하는 모든 레코드, 즉 키워드를 제공하여 검색하는 모든 레코드를 보여주는 페이지로 가져 오는 것입니다. 데모를 단순하게 유지하기 위해 샘플 Book_book 테이블에서 모든 책을 선택합니다. 또한 추가 내비게이션을 위해 결과 세트 및 측면 링크가 표시됩니다. <p> <br> 두 번째 경로는 위의 단계에서 생성 된 결과 세트에서 추가 패싯 검색 기준과 일치하는 레코드를 보여주는 다른 페이지로 우리를 가져옵니다. 측면 검색 링크도 표시됩니다. </p> <world> 실제 구현에서, 측면 링크를 클릭 한 후, 결과 페이지의 측면 필터링은 결과 데이터 세트의 통계 정보를 반영하도록 조정됩니다. 이렇게하면 사용자는 "애드온"상영을 적용하여 "브랜드"를 먼저 추가 한 다음 "가격 범위"등을 추가 할 수 있습니다. <simple> 그러나이 간단한 데모에서는이 접근법을 건너 뛸 것입니다. 모든 측면 검색 및 링크는 원래 데이터 세트에 대한 정보 만 반영합니다. 이것은 첫 번째 제한 사항이며 데모의 개선을위한 첫 번째 영역입니다. <p> 위의 코드에서 알 수 있듯이 실제 함수는 Pinqdemo.php라는 다른 파일에 있습니다. Faceted 검색 기능을 제공하는 관련 코드를 보겠습니다. </p> <class> 패싯 클래스 <create> 먼저, 우리는 패싯을 나타내는 클래스를 만듭니다. 일반적으로 패싯에는 몇 가지 속성이 있어야합니다 <p> ($ data)에서 작동하는 데이터 <oper> <groups> 키는 ($ key) 를 그룹화합니다 키 유형 ($ 유형). 다음 중 하나 일 수 있습니다 정확한 일치를 만들기 위해 전체 문자열을 지정하십시오 <ial> 패턴 일치를 만들기 위해 문자열의 부분 (일반적으로 시작)을 지정하십시오. <value> 값 범위별로 그룹에 값 범위를 지정합니다 <p> . <type> 키 유형이 범위 인 경우 범위의 상한/하한을 결정하기위한 값 단계를 지정해야합니다. 또는 키 유형이 부분 문자열 인 경우, 그룹에 사용되어야하는 첫 번째 문자 수를 지정하려면 숫자를 제공해야합니다 ($ range) </type></p> <is> 그룹화는 패싯에서 가장 중요한 부분입니다. 패싯이 반환 할 수있는 모든 집계 정보는 "그룹화"기준에 따라 다릅니다. 일반적으로 "전체 문자열", "부분 문자열"및 "값 범위"는 가장 일반적으로 사용되는 것입니다. <p> 이 클래스에서 핵심 기능은 데이터 및 패싯 키 속성을 기반으로 패싯 결과 세트를 반환하는 것입니다. 다양한 유형의 키에 대해 데이터를 그룹화하는 방법이 다르다는 것을 알았습니다. 위에서, 우리는 $ 범위로 지정된 단계에서 값 범위별로 데이터를 값 범위별로 그룹화하는 경우 코드의 모습을 보여주었습니다. </p> <and> 패싯 만들기 및 원래 데이터 표시 <f> getfacet () 함수에서 다음 단계를 수행합니다<ul> <data> 추가 처리를 위해 원래 데이터를 pinqtraversable 객체로 변환합니다. <fac> 우리는 3 개의 패싯을 만듭니다. ‘저자’패싯은 필드 저자로 그룹화되며 전체 문자열 그룹입니다. 필드 제목의 '제목'면 및 부분 문자열 그룹화 (시작 6 문자 수); 현장 가격 및 범위 그룹화 (10 단계)의 '가격'면. <get> 마지막으로, 패싯을 가져 와서 템플릿이 데이터와면을 렌더링 할 수 있도록 테스트 2 기능으로 되돌립니다. <li> </li> <fac> 패싯과 필터링 된 데이터를 표시 <time> 대부분의 시간, 패싯은 링크로 표시되어 필터링 된 데이터 세트로 가져옵니다. </time></fac></get></fac></data> </ul></f></and></is></value></ial></groups></oper></p></create></class></simple></world></is></li> <created> 우리는 이미 패싯 검색 결과와 패싯 링크를 표시하기 위해 경로 ( 'demo2/facet/{key}/{value}')를 이미 만들었습니다. <li> <two> 경로는 두 개의 매개 변수를 사용하여 우리가 끄는 키와 해당 키의 값을 반영합니다. 결국 해당 경로에서 호출되는 Test3 기능은 아래에서 발췌됩니다. </two> </li> <dep> 기본적으로, 키에 따라, 우리는 전달 된 값에 해당하는 필터링 (Where Clause의 익명 함수)을 적용하고 추가 스크리닝 된 데이터를 얻습니다. 패싯 데이터의 순서를 지정할 수도 있습니다. </dep></created></two>
마지막으로, 우리는 템플릿에 데이터 (면과 함께)를 표시합니다. 이 경로는 Route 'Demo2'에서 사용하는 것과 동일한 템플릿을 렌더링합니다. 다음, 템플릿을 살펴보고 패싯 링크가 어떻게 표시되는지 살펴 보겠습니다. 부트 스트랩을 사용하고 있으므로 여기에 사용되는 CSS 구성 요소는 친숙해야합니다.

우리는 앱에 의해 생성 된 패싯이 중첩 어레이라는 것을 기억해야합니다. 첫 번째 레이어에서는 모든면의 배열이며, 우리의 경우 각각 총 3 개 (각각 저자, 제목, 저자)가 있습니다.

각면에 대해, 전통적인 방식으로 반복 할 수 있도록 "키 가치"쌍 어레이입니다.

링크의 Uris를 구성하는 방법에 주목하십시오. 외부 루프의 키 (k)와 내부 루프 키 (vv.key)를 사용하여 경로의 매개 변수 ( 'demo2/facet/{key}/{value}')를 모두 사용했습니다. 키 (vv.count)의 수는 템플릿의 디스플레이를 터치하는 데 사용됩니다 (부트 스트랩 배지).

템플릿은 다음과 같이 렌더링됩니다

(첫 번째 입력 페이지와 두 번째는 $ 0에서 $ 10 사이의 가격과 저자가 주문한 패싯 결과를 보여줍니다) . 알겠습니다. 지금까지 우리는 웹 앱에서 측면 검색 기능을 모방했습니다! 우리 가이 시리즈를 마치기 전에, 우리는이 데모를 최종적으로 살펴보고 그것을 개선하기 위해 무엇을 할 수 있는지, 그리고 한계가 무엇인지 볼 것입니다.

개선이 이루어질

전반적으로, 이것은 매우 기초적인 데모입니다. 우리는 단지 기본 구문과 개념을 통해 달려 가서 캔이 운영 된 예로 만들어 냈습니다. 앞에서 보았 듯이 몇 가지 영역을 개선하여보다 유연하게 만들 수 있습니다.

우리는 "애드온"기준 검색 기능을 제공하는 것을 고려해야합니다. 현재 구현은 스크리닝 된 데이터 대신 원본에만 적용되는 패싯 검색을 제한합니다. 이것은 내가 생각할 수있는 가장 중요한 개선입니다.

제한 여기에 구현 된 패싯 검색에는 뿌리 깊은 제한이 있습니다 (그리고 아마도 다른 측면 검색 구현의 경우에 해당) : 우리는 매번 MySQL 서버에서 데이터를 검색하고 있습니다. 이 앱은 silex를 프레임 워크로 사용합니다. Silex, Symfony, Laravel과 같은 단일 감소 프레임 워크의 경우 index.php (또는 app.php)가 경로를 분석하고 컨트롤러의 기능을 호출 할 때마다 호출됩니다.

index.php의 코드를 살펴보면 이것이 아래 코드 라인을 의미합니다.

위 내용은 PINQ- 데이터 세트 - 측면 검색 쿼리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)Mar 03, 2025 am 10:49 AM

종종 키워드와 추적 매개 변수로 혼란스러워하는 긴 URL은 방문자를 방해 할 수 있습니다. URL 단축 스크립트는 솔루션을 제공하여 소셜 미디어 및 기타 플랫폼에 이상적인 간결한 링크를 만듭니다. 이 스크립트는 개별 웹 사이트 a에 유용합니다

Instagram API 소개Instagram API 소개Mar 02, 2025 am 09:32 AM

Instagram은 2012 년 Facebook에서 유명한 인수에 이어 타사 사용을 위해 두 개의 API 세트를 채택했습니다. Instagram Graph API 및 Instagram Basic Display API입니다. 개발자는

Laravel의 플래시 세션 데이터로 작업합니다Laravel의 플래시 세션 데이터로 작업합니다Mar 12, 2025 pm 05:08 PM

Laravel은 직관적 인 플래시 방법을 사용하여 임시 세션 데이터 처리를 단순화합니다. 응용 프로그램에 간단한 메시지, 경고 또는 알림을 표시하는 데 적합합니다. 데이터는 기본적으로 후속 요청에만 지속됩니다. $ 요청-

Laravel Back End : Part 2, React가있는 React 앱 구축Laravel Back End : Part 2, React가있는 React 앱 구축Mar 04, 2025 am 09:33 AM

이것은 Laravel 백엔드가있는 React Application을 구축하는 데있어 시리즈의 두 번째이자 마지막 부분입니다. 이 시리즈의 첫 번째 부분에서는 기본 제품 목록 응용 프로그램을 위해 Laravel을 사용하여 편안한 API를 만들었습니다. 이 튜토리얼에서는 Dev가 될 것입니다

Laravel 테스트에서 단순화 된 HTTP 응답 조롱Laravel 테스트에서 단순화 된 HTTP 응답 조롱Mar 12, 2025 pm 05:09 PM

Laravel은 간결한 HTTP 응답 시뮬레이션 구문을 제공하여 HTTP 상호 작용 테스트를 단순화합니다. 이 접근법은 테스트 시뮬레이션을보다 직관적으로 만들면서 코드 중복성을 크게 줄입니다. 기본 구현은 다양한 응답 유형 단축키를 제공합니다. Illuminate \ support \ Facades \ http를 사용하십시오. http :: 가짜 ([ 'google.com'=> ​​'Hello World', 'github.com'=> ​​[ 'foo'=> 'bar'], 'forge.laravel.com'=>

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법Mar 14, 2025 am 11:42 AM

PHP 클라이언트 URL (CURL) 확장자는 개발자를위한 강력한 도구이며 원격 서버 및 REST API와의 원활한 상호 작용을 가능하게합니다. PHP CURL은 존경받는 다중 프로모토콜 파일 전송 라이브러리 인 Libcurl을 활용하여 효율적인 execu를 용이하게합니다.

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트Mar 13, 2025 pm 12:08 PM

고객의 가장 긴급한 문제에 실시간 인스턴트 솔루션을 제공하고 싶습니까? 라이브 채팅을 통해 고객과 실시간 대화를 나누고 문제를 즉시 해결할 수 있습니다. 그것은 당신이 당신의 관습에 더 빠른 서비스를 제공 할 수 있도록합니다.

2025 PHP 상황 조사 발표2025 PHP 상황 조사 발표Mar 03, 2025 pm 04:20 PM

2025 PHP Landscape Survey는 현재 PHP 개발 동향을 조사합니다. 개발자와 비즈니스에 대한 통찰력을 제공하는 프레임 워크 사용, 배포 방법 및 과제를 탐색합니다. 이 조사는 현대 PHP Versio의 성장을 예상합니다

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구