> 백엔드 개발 > PHP 튜토리얼 > PHP 및 MongoDB를 사용하여 비관계형 데이터베이스 작업을 구현하는 방법

PHP 및 MongoDB를 사용하여 비관계형 데이터베이스 작업을 구현하는 방법

王林
풀어 주다: 2023-06-25 10:38:01
원래의
1311명이 탐색했습니다.

인터넷이 발전하면서 데이터의 양이 급격히 증가했으며 기존 관계형 데이터베이스는 더 이상 데이터 처리 요구 사항을 완전히 충족할 수 없습니다. 새로운 데이터베이스 기술인 비관계형 데이터베이스(NoSQL)는 대용량 데이터와 높은 동시 접속 상황을 더 효과적으로 처리할 수 있습니다. 그중 MongoDB는 Nosql의 대표자 중 하나로 동적 데이터 스키마, 높은 확장성, 고가용성 및 고성능을 지원하며 특히 객체 지향 개발 모델에 적합합니다. 이 기사에서는 PHP와 MongoDB를 사용하여 비관계형 데이터베이스 작업을 구현하는 방법을 소개합니다.

1. MongoDB 및 PHP 확장 설치

MongoDB를 사용하기 전에 먼저 MongoDB 서비스와 해당 PHP 확장을 설치해야 합니다. MongoDB 설치에 대해서는 공식 문서를 참조하시기 바라며 여기서는 자세히 다루지 않겠습니다. 다음 단계를 통해 PHP 확장을 설치할 수 있습니다.

  1. PHP 확장 다운로드: PECL 공식에서 해당 버전의 MongoDB 확장(https://pecl.php.net/package/mongodb) 소스 코드를 다운로드합니다. 웹사이트를 방문하고 압축을 푼다.
  2. PHP 확장 컴파일: 명령줄에 소스 코드 폴더를 입력하고 다음 명령을 실행합니다.

    phpize
    ./configure
    make
    make install
    로그인 후 복사
  3. php.ini 파일 구성: php.ini 파일을 찾아 다음 콘텐츠를 추가합니다.

    extension=mongodb.so
    로그인 후 복사
  4. PHP 서비스 다시 시작: 구성을 적용하려면 PHP 서비스를 다시 시작하세요. 명령 방법은 다음과 같이 시스템에 따라 다릅니다.

    systemctl restart php-fpm
    로그인 후 복사

2. MongoDB 데이터베이스에 연결

MongoDB 데이터베이스에 연결하려면 구체적인 작업은 다음과 같습니다:

  1. 연결 만들기: MongoClient 클래스를 사용하여 연결을 만듭니다. 생성자의 매개변수는 MongoDB 서비스의 IP 주소와 포트 번호입니다. .

    $client = new MongoClient("mongodb://127.0.0.1:27017");
    로그인 후 복사
  2. 데이터베이스 선택 : selectDB 방식을 사용하여 운영할 데이터베이스를 선택합니다.

    $db = $client->selectDB('test');
    로그인 후 복사

3. 데이터 삽입

MongoDB는 JSON 형식의 데이터 저장을 지원하므로 데이터를 삽입하면 데이터를 JSON 형식으로 변환할 수 있습니다. 구체적인 작업은 다음과 같습니다.

  1. 문서 만들기: MongoDB의 문서 클래스 MongoDBBSONDocument를 사용하여 문서 개체를 만듭니다.

    $doc = new MongoDBBSONDocument([
        'name' => '张三',
        'age' => 20,
        'sex' => '男',
        'address' => '北京市',
    ]);
    로그인 후 복사
  2. 데이터 삽입: MongoDB의 컬렉션 클래스 MongoCollection의 insertOne 메서드를 사용하여 데이터를 삽입합니다.

    $collection = $db->selectCollection('users');
    $collection->insertOne($doc);
    로그인 후 복사

4. 데이터 쿼리

MongoDB는 다양한 강력한 쿼리 및 집계 작업을 지원합니다. 구체적인 작업은 다음과 같습니다.

  1. 문서 쿼리: 첫 번째 매개변수는 find 메서드를 사용합니다. 쿼리 조건 및 두 번째 각 매개 변수는 지정된 필드 쿼리, 정렬 등과 ​​같은 선택 사항입니다.

    $collection = $db->selectCollection('users');
    $cursor = $collection->find([
        'age' => ['$gt' => 18]
    ], [
        'projection' => ['name' => 1, 'age' => 1],
        'sort' => ['age' => 1],
    ]);
    foreach ($cursor as $doc) {
        echo $doc['name'] . ' ' . $doc['age'] . "
    ";
    }
    로그인 후 복사
  2. 집계 작업: 집계 방법과 같은 집계 방법을 사용하여 다중 수준 집계 계산을 수행하여 복잡한 쿼리 요구 사항을 달성합니다.

    $collection = $db->selectCollection('users');
    $cursor = $collection->aggregate([
        ['$match' => ['age' => ['$gt' => 18]]],
        ['$group' => [
            '_id' => '$sex',
            'count' => ['$sum' => 1]
        ]],
        ['$sort' => ['count' => -1]],
    ]);
    foreach ($cursor as $doc) {
        echo $doc['_id'] . ' ' . $doc['count'] . "
    ";
    }
    로그인 후 복사

5. 데이터 업데이트 및 삭제

MongoDB는 단일 및 일괄 업데이트 및 삭제 작업을 지원합니다. 구체적인 작업은 다음과 같습니다.

  1. 단일 업데이트: 단일 데이터 조각을 업데이트하려면 updateOne 메서드를 사용합니다. 첫 번째 매개변수는 쿼리 조건이고, 두 번째 매개변수는 업데이트할 데이터입니다.

    $collection = $db->selectCollection('users');
    $collection->updateOne(
        ['name' => '张三'],
        ['$set' => ['age' => 21]]
    );
    로그인 후 복사
  2. 다중 업데이트: updateMany 메서드를 사용하여 데이터를 일괄 업데이트합니다.

    $collection = $db->selectCollection('users');
    $collection->updateMany(
        ['sex' => '男'],
        ['$inc' => ['age' => 1]]
    );
    로그인 후 복사
  3. 단일 삭제: deleteOne 메서드를 사용하여 단일 데이터 조각을 삭제합니다. 여기서 첫 번째 매개변수는 쿼리 조건입니다.

    $collection = $db->selectCollection('users');
    $collection->deleteOne(['name' => '张三']);
    로그인 후 복사
  4. 다중 삭제: 데이터를 일괄 삭제하려면 deleteMany 메서드를 사용하세요.

    $collection = $db->selectCollection('users');
    $collection->deleteMany(['sex' => '男']);
    로그인 후 복사

6. 요약

위는 PHP와 MongoDB를 사용하여 비관계형 데이터베이스 작업을 구현하는 방법에 대한 기본 소개입니다. 다양한 비즈니스 시나리오의 구체적인 구현 방법은 다를 수 있으며 독자는 이에 따라 조정하고 확장할 수 있습니다. 실제 상황. MongoDB는 복잡한 비즈니스 요구 사항을 더 잘 충족할 수 있는 풍부한 작업 API와 집계 방법을 제공합니다.

위 내용은 PHP 및 MongoDB를 사용하여 비관계형 데이터베이스 작업을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿