PHP 마스터 | MongoDB 인덱싱, 1 부
인덱싱은 MongoDB와의 작업의 가장 중요한 개념 중 하나입니다. 인덱싱은 읽을 전체 문서의 수를 줄임으로써 성능과 처리량을 극적으로 증가시켜 응용 프로그램의 성능을 향상시킬 수 있기 때문에 적절한 이해가 중요합니다. 인덱스는 이해하기 어려울 수 있기 때문에이 두 부분으로 구성된 시리즈는 자세히 살펴볼 것입니다. 이 기사에서는 다음과 같은 5 가지 유형의 인덱스를 살펴볼 것입니다.
<_> 기본 _id 인덱스 2 차 지수- 화합물 지수
- 논의 할 다른 유형도 있습니다. 그러나 나는 분명한 이해를 제공하고 혼란을 피하기 위해 Part 2를 논리적으로 유지했습니다. 컬렉션에서 둘 이상의 인덱스를 정의 할 수 있지만 쿼리는 실행 중에 하나의 인덱스 만 사용할 수 있습니다. 사용 가능한 옵션 중에서 최상의 인덱스를 선택하려는 결정은 MongoDB의 쿼리 옵션에 의해 런타임에 이루어집니다. 이 기사에서는 MongoDB 개념 (컬렉션, 문서 등)을 기본적으로 이해하고 PHP (찾기 및 삽입)를 사용하여 기본 쿼리를 수행한다고 가정합니다. 그렇지 않다면, 초보자 기사 : Mongodb 및 Mongodb 소개를 재 방문하는 것이 좋습니다. 이 시리즈의 경우 다음 구조가있는 500 개의 문서로 채워진 게시물이라는 컬렉션이 있다고 가정합니다.
- 이제 다양한 유형의 인덱싱을 자세히 살펴 보겠습니다. <_> 기본 _id 인덱스 기본적으로 MongoDB는 각 컬렉션의 _id 필드에서 기본 색인을 만듭니다. 각 문서에는 고유 한 _ID 필드가 기본 키, 12 바이트 객체가 있습니다. 사용 가능한 다른 색인이 없으면 기본적으로 모든 종류의 쿼리에 사용됩니다. 컬렉션의 인덱스를 보려면 MongoDB 쉘을 열고 다음을 수행하십시오.
- getIndexes () 메소드는 컬렉션의 모든 인덱스를 반환합니다. 보시다시피, 우리는 이름 _id_ 의 기본 인덱스가 있습니다. 키 필드는 인덱스가 _id 필드에 있고 1의 값은 오름차순 순서를 나타냅니다. 다음 섹션에서 주문에 대해 배울 것입니다.
2 차 지수
_ID 필드가 아닌 필드에서 인덱싱을 사용하려는 경우 사용자 정의 인덱스를 정의해야합니다. user_name 필드를 기반으로 게시물을 검색하고 싶다고 가정하십시오. 이 경우 컬렉션의 user_name 필드에서 사용자 정의 색인을 정의합니다. 기본 인덱스 이외의 이러한 사용자 정의 인덱스를 보조 인덱스라고합니다.
데이터베이스에 대한 인덱싱의 영향을 입증하려면 먼저 인덱싱없이 쿼리 성능을 간단히 분석하겠습니다. 이를 위해 쿼리를 실행하여 "Jim Alexandar"가있는 user_name이있는 모든 게시물을 찾습니다.
인덱싱과 관련하여 종종 사용되는 중요한 방법은 인덱싱과 관련된 정보를 반환하는 설명 ()입니다. 위의 설명 ()의 출력은 다음과 같습니다.
볼 가치가있는 중요한 키 중 일부는 다음과 같습니다.<span>{ </span> <span>"_id": <span>ObjectId</span>("5146bb52d852470060001f4"), </span> <span>"comments": { </span> <span>"0": "This is the first comment", </span> <span>"1": "This is the second comment" </span> <span>}, </span> <span>"post_likes": 40, </span> <span>"post_tags": { </span> <span>"0": "MongoDB", </span> <span>"1": "Tutorial", </span> <span>"2": "Indexing" </span> <span>}, </span> <span>"post_text": "Hello Readers!! This is my post text", </span> <span>"post_type": "private", </span> <span>"user_name": "Mark Anthony" </span><span>}</span>
로그인 후 복사로그인 후 복사커서 - 쿼리에 사용 된 색인을 나타냅니다.
btreecursorBasicCursor 는 기본 _id 인덱스가 사용되었고 MongoDB는 전체 컬렉션을 검색해야했음을 나타냅니다. 앞으로도 인덱싱을 적용 할 때
- 가
- basiccursor .
n - 쿼리가 반환 한 문서 수를 나타냅니다 (이 경우 하나의 문서). nscanned - 데이터베이스 작동 중에 스캔 한 문서 수를 나타냅니다. 이상적으로 N은 NSCANCAND와 동일해야하므로 최소 수의 문서가 검색되었음을 의미합니다. 이제 동일한 쿼리를 실행하지만 보조 인덱스를 사용해 보겠습니다. 인덱스를 만들려면 MongoDB 쉘에서 다음을 실행하십시오. user_name 필드에서 인덱스를 만들었습니다 restindex () 메소드를 사용하여 게시물 수집에서. 검색에 대한 오름차순 (1) 또는 내림차순 (-1) 순서를 나타내는 메소드에 주문 인수의 값을 신분했다고 확신합니다. 이를 이해하려면 각 문서에는 타임 스탬프 필드가 있습니다. 가장 최근의 게시물을 먼저 원한다면 하강 순서를 사용합니다. 가장 오래된 게시물의 경우 오름차순 순서를 선택합니다. 인덱스를 만들면 동일한 find () 및 explic () 메소드가 이전과 쿼리를 실행하고 분석하는 데 사용됩니다. 출력은 다음과 같습니다. 출력은 쿼리가 name (이전에 정의한)를 사용했으며 인덱싱없이 이전 쿼리에서 검색 한 500 개의 문서와 달리 하나의 문서 만 스캔했음을 보여줍니다.
현재 모든 MongoDB 인덱스는 알고리즘에서 Btree 데이터 구조를 사용하고 Btreecursor는 기본 커서입니다. Btreecursor에 대한 자세한 논의는이 기사에 대한 범위를 벗어나지 만 더 이상의 이해에는 영향을 미치지 않습니다.
위의 비교는 인덱스가 쿼리 성능을 극적으로 향상시킬 수있는 방법을 나타냅니다.
화합물 지수
쿼리가 둘 이상의 필드를 사용하는 경우가 있습니다. 이러한 경우 복합 지수를 사용할 수 있습니다. post_type 및 post_likes 필드를 모두 사용하는 다음 쿼리를 고려하십시오.
이 쿼리를 inctive ()로 분석하면 다음 결과가 나타납니다.이 결과는 쿼리가 BasicCursor를 사용하고 500 개의 문서가 모두 스캔되어 하나의 문서를 검색 함을 보여줍니다.
<span>{ </span> <span>"_id": <span>ObjectId</span>("5146bb52d852470060001f4"), </span> <span>"comments": { </span> <span>"0": "This is the first comment", </span> <span>"1": "This is the second comment" </span> <span>}, </span> <span>"post_likes": 40, </span> <span>"post_tags": { </span> <span>"0": "MongoDB", </span> <span>"1": "Tutorial", </span> <span>"2": "Indexing" </span> <span>}, </span> <span>"post_text": "Hello Readers!! This is my post text", </span> <span>"post_type": "private", </span> <span>"user_name": "Mark Anthony" </span><span>}</span>
로그인 후 복사로그인 후 복사이제 쿼리를 분석하면 다음 결과가 나타납니다.
여기서 매우 중요한 점은 여러 필드에 정의 된 복합 지수를 사용하여 이러한 필드의 하위 집합을 쿼리 할 수 있다는 것입니다. 예를 들어, 화합물 인덱스 {Field1, Field2, Field3}이 있다고 가정합니다. 이 색인은 다음을 쿼리하는 데 사용할 수 있습니다.필드 1
필드 1, Field2 Field1, Field2, Field3 따라서 index {Field1, Field2, Field3}을 정의한 경우 별도의 {Field1} 및 {Field1, Field2} 인덱스를 정의 할 필요가 없습니다. 그러나 Field2 및 Field2, Field3을 쿼리하는 동안이 화합물 인덱스가 필요한 경우 Optimizer가 원하는 인덱스를 선택하지 않으면 Hint ()를 사용할 수 있습니다. hint () 메소드를 사용하여 MongoDB가 기본 선택 및 쿼리 최적화 프로세스를 지정하고 재정의하는 인덱스를 사용하도록 강요 할 수 있습니다. 아래와 같이 인덱스에 사용 된 필드 이름을 인수로 지정할 수 있습니다.
이를 통해 쿼리는 post_type 및 post_likes 필드에 정의 된 화합물 지수를 사용합니다.
멀티 킨 인덱스 배열 필드에서 인덱싱이 수행되면 멀티 킨 인덱스라고합니다. 우리의 게시물 문서를 다시 고려하십시오. Post_tags에 멀티 킨 인덱스를 적용 할 수 있습니다. 멀티 킨 인덱스는 배열의 각 요소를 색인화 하므로이 경우 post_tags 값에 대해 별도의 인덱스가 생성됩니다. 곧. - 어레이 필드의 인덱스는 각 값의 인덱싱으로 인해 많은 메모리를 소비하므로 매우 선택적으로 사용해야합니다.
다중 화합물 지수 우리는 다중 화합물 지수를 만들 수 있지만 인덱스의 최대 한 필드가 배열 일 수 있다는 제한이 있습니다. 따라서 Field1이 문자열로, [Field2, Field3]가 배열로 있으면 두 필드가 배열이므로 인덱스 {Field2, Field3}을 정의 할 수 없습니다. 아래 예에서는 Post_tags 및 User_Name 필드에 대한 색인을 만듭니다.
색인 제한 제한 및 고려 사항 정규 표현식, 부정 연산자 (예 : $ ne, $ not 등), 산술 연산자 (예 : $ mod 등), $ where의 JavaScript 표현식을 사용하는 쿼리에서 인덱싱을 사용할 수 없다는 것을 아는 것이 중요합니다. 조항 및 다른 경우. 인덱싱 운영에는 자체 비용도 제공됩니다. 각 인덱스는 공간을 차지할뿐만 아니라 컬렉션의 각 삽입, 업데이트 및 삭제에서 추가 오버 헤드를 유발합니다. 각 컬렉션에 대한 읽기 비율을 고려해야합니다. 인덱싱은 무거운 컬렉션에 도움이되지만 쓰기가 많은 컬렉션에는 적합하지 않을 수 있습니다. MongoDB는 RAM의 색인을 유지합니다. 총 지수 크기가 RAM 제한을 초과하지 않도록하십시오. 그렇다면 일부 인덱스는 RAM에서 제거되므로 쿼리가 느려집니다. 또한 컬렉션은 최대 64 개의 인덱스를 가질 수 있습니다. 요약 그게 전부입니다. 요약하면, 적절한 인덱싱 접근법이 선택된 경우 인덱스는 응용 프로그램에 매우 유리합니다. 다음 부분에서는 임베디드 문서, 하위 문서 및 주문에 인덱스를 사용하는 것을 살펴 봅니다. 계속 지켜봐! Fotolia를 통한 이미지
MongoDB Indexing 데이터베이스 관리에서 MongoDB 인덱싱의 중요성은 무엇입니까? MongoDB 인덱싱은 어떻게 작동합니까? MongoDB의 다양한 유형의 인덱스는 무엇입니까?
MongoDB는 개선에 사용할 수있는 여러 유형의 인덱스를 지원합니다. 쿼리의 성능. 여기에는 단일 필드, 화합물, 멀티 키, 텍스트, 2D 및 2dsphere 인덱스가 포함됩니다. 각 유형의 인덱스는 특정 목적을 제공하며 다른 유형의 쿼리에 사용됩니다. 예를 들어, 단일 필드 및 화합물 지수는 각각 단일 또는 다중 필드의 쿼리에 사용됩니다. 멀티 킨 인덱스는 배열에 사용되며 텍스트 인덱스는 문자열 내용에 사용됩니다.
mongodb에서 인덱스를 만드는 방법createIndex () 메서드를 사용하여 mongodb에서 인덱스를 만들 수 있습니다. . 이 방법은 인덱스가 아직 존재하지 않는 경우 지정된 필드에서 인덱스를 만듭니다. 이 메소드는 필드 또는 필드 인덱스와 추가 옵션을 지정할 수있는 옵션 문서의 두 매개 변수를 가져옵니다.
MongoDB에서 여러 인덱스를 생성 할 수 있습니까? MongoDB의 색인. 그러나 인덱스는 쿼리 성능을 향상 시키지만 시스템 리소스, 특히 디스크 공간 및 메모리를 소비한다는 점에 유의해야합니다. 따라서 자주 쿼리 될 필드에서 신중하고 인덱스를 만드는 것이 중요합니다.mongodb에서 색인을 색인 할 필드를 선택하는 방법은 무엇입니까?
MongoDB는 응용 프로그램의 쿼리 패턴에 크게 의존합니다. 정렬 작업에 자주 쿼리되거나 사용되는 필드는 인덱싱을위한 좋은 후보입니다. 또한, 고유성이 높은 필드는 쿼리를 실행할 때 MongoDB가 스캔 해야하는 문서의 수를 크게 줄일 수 있기 때문에 색인화를위한 좋은 후보자입니다.
MongoDB에 인덱스가 있는지 어떻게 확인할 수 있습니까?getIndexes () 메소드를 사용하여 MongoDB에 인덱스가 있는지 확인할 수 있습니다. 이 메소드는 기본적으로 생성 된 _id 인덱스를 포함하여 컬렉션의 모든 인덱스 목록을 리턴합니다.
Mongodb에서 인덱스를 삭제할 수 있습니까?예, 인덱스를 삭제할 수 있습니다. dropIndex () 메소드를 사용한 mongodb. 이 메소드는 컬렉션에서 지정된 색인을 제거합니다.
MongoDB의 인덱스 교차점은 무엇입니까?MongoDB의 쓰기 작업에 대한 인덱싱의 영향은 무엇입니까? - basiccursor .
위 내용은 PHP 마스터 | MongoDB 인덱싱, 1 부의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

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

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

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

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

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

PHP는 여전히 역동적이며 현대 프로그래밍 분야에서 여전히 중요한 위치를 차지하고 있습니다. 1) PHP의 단순성과 강력한 커뮤니티 지원으로 인해 웹 개발에 널리 사용됩니다. 2) 유연성과 안정성은 웹 양식, 데이터베이스 작업 및 파일 처리를 처리하는 데 탁월합니다. 3) PHP는 지속적으로 발전하고 최적화하며 초보자 및 숙련 된 개발자에게 적합합니다.

PHP와 Python은 고유 한 장점과 단점이 있으며 선택은 프로젝트 요구와 개인 선호도에 달려 있습니다. 1.PHP는 대규모 웹 애플리케이션의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 데이터 과학 및 기계 학습 분야를 지배합니다.

PHP는 특히 빠른 개발 및 동적 컨텐츠를 처리하는 데 웹 개발에 적합하지만 데이터 과학 및 엔터프라이즈 수준의 애플리케이션에는 적합하지 않습니다. Python과 비교할 때 PHP는 웹 개발에 더 많은 장점이 있지만 데이터 과학 분야에서는 Python만큼 좋지 않습니다. Java와 비교할 때 PHP는 엔터프라이즈 레벨 애플리케이션에서 더 나빠지지만 웹 개발에서는 더 유연합니다. JavaScript와 비교할 때 PHP는 백엔드 개발에서 더 간결하지만 프론트 엔드 개발에서는 JavaScript만큼 좋지 않습니다.
