Heim >Backend-Entwicklung >PHP-Tutorial >So implementieren Sie nicht relationale Datenbankoperationen mit PHP und MongoDB
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:
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
Konfigurieren Sie die php.ini-Datei: Suchen Sie die php.ini-Datei und fügen Sie den folgenden Inhalt hinzu:
extension=mongodb.so
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:
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");
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:
Dokument erstellen: Verwenden Sie die Dokumentklasse MongoDBBSONDocument von MongoDB, um ein Dokumentobjekt zu erstellen.
$doc = new MongoDBBSONDocument([ 'name' => '张三', 'age' => 20, 'sex' => '男', 'address' => '北京市', ]);
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:
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'] . " "; }
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:
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]] );
Mehrfache Updates: Verwenden Sie die updateMany-Methode, um Daten stapelweise zu aktualisieren.
$collection = $db->selectCollection('users'); $collection->updateMany( ['sex' => '男'], ['$inc' => ['age' => 1]] );
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' => '张三']);
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!