목차
Faceted Search에 PINQ를 사용하면 몇 가지 이점이 있습니다. 첫째, 복잡한 쿼리를 생성하는 프로세스를 단순화하여 개발자의 시간과 노력을 절약 할 수 있습니다. 둘째, 광범위한 데이터 유형과 구조를 처리 할 수있는 강력하고 유연한 쿼리 언어를 제공합니다. 마지막으로, 그것은 널리 사용되는 프로그래밍 언어 인 PHP를 기반으로하므로 개발자가 배우고 사용하기가 더 쉬워집니다.
PINQ는 강력하고 유연한 것을 사용하여 검색 결과의 정확성을 보장하는 방법을 어떻게 보장합니까? 여러 기준에 따라 데이터를 정확하게 필터링하고 정렬 할 수있는 쿼리 언어. 이를 통해 정확하고 관련 검색 결과를 제공 할 수 있습니다.
백엔드 개발 PHP 튜토리얼 PINQ- 데이터 세트 - 측면 검색 쿼리

PINQ- 데이터 세트 - 측면 검색 쿼리

Feb 20, 2025 pm 12:29 PM

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으로 문의하세요.

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP 및 Python : 두 가지 인기있는 프로그래밍 언어를 비교합니다 PHP 및 Python : 두 가지 인기있는 프로그래밍 언어를 비교합니다 Apr 14, 2025 am 12:13 AM

PHP와 Python은 각각 고유 한 장점이 있으며 프로젝트 요구 사항에 따라 선택합니다. 1.PHP는 웹 개발, 특히 웹 사이트의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 간결한 구문을 가진 데이터 과학, 기계 학습 및 인공 지능에 적합하며 초보자에게 적합합니다.

PHP에서 보안 비밀번호 해싱을 설명하십시오 (예 : Password_hash, Password_Verify). 왜 MD5 또는 SHA1을 사용하지 않습니까? PHP에서 보안 비밀번호 해싱을 설명하십시오 (예 : Password_hash, Password_Verify). 왜 MD5 또는 SHA1을 사용하지 않습니까? Apr 17, 2025 am 12:06 AM

PHP에서 Password_hash 및 Password_Verify 기능을 사용하여 보안 비밀번호 해싱을 구현해야하며 MD5 또는 SHA1을 사용해서는 안됩니다. 1) Password_hash는 보안을 향상시키기 위해 소금 값이 포함 된 해시를 생성합니다. 2) Password_verify 암호를 확인하고 해시 값을 비교하여 보안을 보장합니다. 3) MD5 및 SHA1은 취약하고 소금 값이 부족하며 현대 암호 보안에는 적합하지 않습니다.

PHP 실행 : 실제 예제 및 응용 프로그램 PHP 실행 : 실제 예제 및 응용 프로그램 Apr 14, 2025 am 12:19 AM

PHP는 전자 상거래, 컨텐츠 관리 시스템 및 API 개발에 널리 사용됩니다. 1) 전자 상거래 : 쇼핑 카트 기능 및 지불 처리에 사용됩니다. 2) 컨텐츠 관리 시스템 : 동적 컨텐츠 생성 및 사용자 관리에 사용됩니다. 3) API 개발 : 편안한 API 개발 및 API 보안에 사용됩니다. 성능 최적화 및 모범 사례를 통해 PHP 애플리케이션의 효율성과 유지 보수 성이 향상됩니다.

PHP : 웹 개발의 핵심 언어 PHP : 웹 개발의 핵심 언어 Apr 13, 2025 am 12:08 AM

PHP는 서버 측에서 널리 사용되는 스크립팅 언어이며 특히 웹 개발에 적합합니다. 1.PHP는 HTML을 포함하고 HTTP 요청 및 응답을 처리 할 수 ​​있으며 다양한 데이터베이스를 지원할 수 있습니다. 2.PHP는 강력한 커뮤니티 지원 및 오픈 소스 리소스를 통해 동적 웹 컨텐츠, 프로세스 양식 데이터, 액세스 데이터베이스 등을 생성하는 데 사용됩니다. 3. PHP는 해석 된 언어이며, 실행 프로세스에는 어휘 분석, 문법 분석, 편집 및 실행이 포함됩니다. 4. PHP는 사용자 등록 시스템과 같은 고급 응용 프로그램을 위해 MySQL과 결합 할 수 있습니다. 5. PHP를 디버깅 할 때 error_reporting () 및 var_dump ()와 같은 함수를 사용할 수 있습니다. 6. 캐싱 메커니즘을 사용하여 PHP 코드를 최적화하고 데이터베이스 쿼리를 최적화하며 내장 기능을 사용하십시오. 7

HTTP 요청 방법 (Get, Post, Put, Delete 등)이란 무엇이며 언제 각각을 사용해야합니까? HTTP 요청 방법 (Get, Post, Put, Delete 등)이란 무엇이며 언제 각각을 사용해야합니까? Apr 09, 2025 am 12:09 AM

HTTP 요청 방법에는 각각 리소스를 확보, 제출, 업데이트 및 삭제하는 데 사용되는 Get, Post, Put and Delete가 포함됩니다. 1. GET 방법은 리소스를 얻는 데 사용되며 읽기 작업에 적합합니다. 2. 게시물은 데이터를 제출하는 데 사용되며 종종 새로운 리소스를 만드는 데 사용됩니다. 3. PUT 방법은 리소스를 업데이트하는 데 사용되며 완전한 업데이트에 적합합니다. 4. 삭제 방법은 자원을 삭제하는 데 사용되며 삭제 작업에 적합합니다.

self ::, parent ::, 그리고 static :: php oop의 차이점을 설명하십시오. self ::, parent ::, 그리고 static :: php oop의 차이점을 설명하십시오. Apr 09, 2025 am 12:04 AM

phpoop에서 self ::는 현재 클래스를 말하며, Parent ::는 부모 클래스를 말하며, static ::는 늦은 static 바인딩에 사용됩니다. 1. self :: 정적 방법과 일정한 호출에 사용되지만 늦은 정적 바인딩을 지원하지는 않습니다. 2.parent :: 하위 클래스가 상위 클래스 방법을 호출하는 데 사용되며 개인 방법에 액세스 할 수 없습니다. 3. Static ::는 상속 및 다형성에 적합한 후기 정적 결합을 지원하지만 코드의 가독성에 영향을 줄 수 있습니다.

PHP는 파일 업로드를 어떻게 단단히 처리합니까? PHP는 파일 업로드를 어떻게 단단히 처리합니까? Apr 10, 2025 am 09:37 AM

PHP는 $ \ _ 파일 변수를 통해 파일 업로드를 처리합니다. 보안을 보장하는 방법에는 다음이 포함됩니다. 1. 오류 확인 확인, 2. 파일 유형 및 크기 확인, 3 파일 덮어 쓰기 방지, 4. 파일을 영구 저장소 위치로 이동하십시오.

스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까? 스칼라 유형, 반환 유형, 노조 유형 및 무효 유형을 포함한 PHP 유형의 힌트 작업은 어떻게 작동합니까? Apr 17, 2025 am 12:25 AM

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

See all articles