So implementieren Sie nicht relationale Datenbankoperationen mit PHP und MongoDB

王林
Freigeben: 2023-06-25 10:38:01
Original
1239 Leute haben es durchsucht

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
    Nach dem Login kopieren
  3. Konfigurieren Sie die php.ini-Datei: Suchen Sie die php.ini-Datei und fügen Sie den folgenden Inhalt hinzu:

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

    systemctl restart php-fpm
    Nach dem Login kopieren

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");
    Nach dem Login kopieren
  2. Datenbank auswählen: Verwenden Sie die Methode selectDB, um die zu bedienende Datenbank auszuwählen.

    $db = $client->selectDB('test');
    Nach dem Login kopieren

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' => '北京市',
    ]);
    Nach dem Login kopieren
  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);
    Nach dem Login kopieren

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'] . "
    ";
    }
    Nach dem Login kopieren
  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'] . "
    ";
    }
    Nach dem Login kopieren

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]]
    );
    Nach dem Login kopieren
  2. Mehrfache Updates: Verwenden Sie die updateMany-Methode, um Daten stapelweise zu aktualisieren.

    $collection = $db->selectCollection('users');
    $collection->updateMany(
        ['sex' => '男'],
        ['$inc' => ['age' => 1]]
    );
    Nach dem Login kopieren
  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' => '张三']);
    Nach dem Login kopieren
  4. Mehrfache Löschungen: Verwenden Sie die Methode deleteMany, um Daten stapelweise zu löschen.

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

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!