Heim  >  Artikel  >  Backend-Entwicklung  >  So implementieren Sie nicht relationale Datenbankoperationen mit PHP und MongoDB

So implementieren Sie nicht relationale Datenbankoperationen mit PHP und MongoDB

王林
王林Original
2023-06-25 10:34:381229Durchsuche

Mit der Entwicklung des Internets hat die Datenmenge dramatisch zugenommen und herkömmliche relationale Datenbanken können die Anforderungen der Datenverarbeitung nicht mehr vollständig erfüllen. Als neue Datenbanktechnologie kann die nicht relationale Datenbank (NoSQL) große Datenmengen und Situationen mit hohem gleichzeitigem Zugriff besser verarbeiten. Unter diesen unterstützt MongoDB als einer der Vertreter von Nosql dynamische Datenschemata, hohe Skalierbarkeit, hohe Verfügbarkeit und hohe Leistung und eignet sich besonders für objektorientierte Entwicklungsmodelle. In diesem Artikel wird erläutert, wie Sie mit PHP und MongoDB nicht relationale Datenbankoperationen implementieren.

1. Installieren Sie MongoDB- und PHP-Erweiterungen

Bevor Sie MongoDB verwenden, müssen Sie zunächst den MongoDB-Dienst und die entsprechende PHP-Erweiterung installieren. Informationen zur Installation von MongoDB finden Sie in der offiziellen Dokumentation. Wir gehen hier nicht näher darauf ein. Sie können die PHP-Erweiterung durch die folgenden Schritte installieren:

  1. Laden Sie die PHP-Erweiterung herunter: Laden Sie den Quellcode der entsprechenden Version der MongoDB-Erweiterung (https://pecl.php.net/package/mongodb) vom PECL-Beamten herunter Laden Sie die Website herunter und entpacken Sie sie.
  2. PHP-Erweiterung kompilieren: Geben Sie den Quellcode-Ordner in die Befehlszeile ein und führen Sie den folgenden Befehl aus:

    phpize
    ./configure
    make
    make install
  3. Konfigurieren Sie die php.ini-Datei: Suchen Sie die php.ini-Datei und fügen Sie den folgenden Inhalt hinzu:

    extension=mongodb.so
  4. PHP-Dienst neu starten: Starten Sie den PHP-Dienst neu, damit die Konfiguration wirksam wird, wie zum Beispiel:

    systemctl restart php-fpm

2. Stellen Sie eine Verbindung zur MongoDB-Datenbank her.

Um eine Verbindung zur MongoDB-Datenbank herzustellen, müssen Sie Folgendes tun: Sie müssen den von MongoDB bereitgestellten PHP-Treiber verwenden:

  1. Erstellen Sie eine Verbindung: Verwenden Sie die MongoClient-Klasse, um eine Verbindung zu erstellen. Die Parameter ihres Konstruktors sind die IP-Adresse und die Portnummer des MongoDB-Dienstes .

    $client = new MongoClient("mongodb://127.0.0.1:27017");
  2. Datenbank auswählen: Verwenden Sie die Methode selectDB, um die zu bedienende Datenbank auszuwählen.

    $db = $client->selectDB('test');

3. Daten einfügen

MongoDB unterstützt die Datenspeicherung im JSON-Format, sodass durch das Einfügen von Daten die Daten in das JSON-Format konvertiert werden können. Die spezifischen Vorgänge lauten wie folgt:

  1. Dokument erstellen: Verwenden Sie die Dokumentklasse MongoDBBSONDocument von MongoDB, um ein Dokumentobjekt zu erstellen.

    $doc = new MongoDBBSONDocument([
        'name' => '张三',
        'age' => 20,
        'sex' => '男',
        'address' => '北京市',
    ]);
  2. Daten einfügen: Verwenden Sie die Methode insertOne der Sammlungsklasse MongoCollection von MongoDB, um Daten einzufügen.

    $collection = $db->selectCollection('users');
    $collection->insertOne($doc);

4. Daten abfragen

MongoDB unterstützt eine Vielzahl leistungsstarker Abfrage- und Aggregationsoperationen:

  1. Dokumente abfragen: Verwenden Sie die Suchmethode, um Dokumente abzufragen Abfragebedingung und die zweite Jeder Parameter ist optional, z. B. das Abfragen bestimmter Felder, das Sortieren usw.

    $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. Aggregationsvorgang: Verwenden Sie Aggregationsmethoden, z. B. die Aggregationsmethode, um mehrstufige Aggregationsberechnungen durchzuführen und komplexe Abfrageanforderungen zu erfüllen.

    $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. Daten aktualisieren und löschen

MongoDB unterstützt Einzel- und Stapelaktualisierungs- und Löschvorgänge:

  1. Einzelaktualisierung: Verwenden Sie die updateOne-Methode, um ein einzelnes Datenelement zu aktualisieren Der erste Parameter ist die Abfragebedingung. Der zweite Parameter sind die zu aktualisierenden Daten.

    $collection = $db->selectCollection('users');
    $collection->updateOne(
        ['name' => '张三'],
        ['$set' => ['age' => 21]]
    );
  2. Mehrfache Updates: Verwenden Sie die updateMany-Methode, um Daten stapelweise zu aktualisieren.

    $collection = $db->selectCollection('users');
    $collection->updateMany(
        ['sex' => '男'],
        ['$inc' => ['age' => 1]]
    );
  3. Einzelne Löschung: Verwenden Sie die Methode deleteOne, um ein einzelnes Datenelement zu löschen, wobei der erste Parameter die Abfragebedingung ist.

    $collection = $db->selectCollection('users');
    $collection->deleteOne(['name' => '张三']);
  4. Mehrfache Löschungen: Verwenden Sie die Methode deleteMany, um Daten stapelweise zu löschen.

    $collection = $db->selectCollection('users');
    $collection->deleteMany(['sex' => '男']);

6. Zusammenfassung

Das Obige ist eine grundlegende Einführung in die Verwendung von PHP und MongoDB zur Implementierung nicht relationaler Datenbankoperationen. Die spezifischen Implementierungsmethoden verschiedener Geschäftsszenarien können unterschiedlich sein und können vom Leser entsprechend angepasst und erweitert werden tatsächliche Situation. MongoDB bietet umfangreiche Betriebs-APIs und Aggregationsmethoden, um komplexe Geschäftsanforderungen besser zu erfüllen.

Das obige ist der detaillierte Inhalt vonSo implementieren Sie nicht relationale Datenbankoperationen mit PHP und MongoDB. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn