Heim > Backend-Entwicklung > PHP-Tutorial > Ein Pokemon -Crashkurs auf CouchDB

Ein Pokemon -Crashkurs auf CouchDB

Jennifer Aniston
Freigeben: 2025-02-14 08:30:12
Original
602 Leute haben es durchsucht

Dieses Tutorial bietet eine praktische Anleitung zur Verwendung von CouchDB, einer NoSQL -Datenbank, über seine HTTP -API mit PHP. Wir werden die theoretischen Aspekte überspringen und direkt in die Durchführung von Datenbankvorgängen eintauchen. Wir gehen davon aus, dass Sie CouchDB und Futon (seine Webadministratorkonsole) bereits eingerichtet haben.

A Pokemon Crash Course on CouchDB

Hinweis: Wir verwenden den Einfachheit halber localhost. Wenn Sie ein VM verwenden, passen Sie entsprechend an (z. B. Verwendung eines benutzerdefinierten Vhost- und weitergeleiteten Ports).

Schlüsselkonzepte:

  • CouchDB -Grundlagen: Eine NoSQL -Datenbank mit JSON für Speicher, JavaScript für Abfragen und eine HTTP -API.
  • Dokumentstruktur: Daten werden in einzelnen JSON -Dokumenten gespeichert; Kein festes Schema oder Tabellen.
  • http api: Verwenden Sie HTTP -Anforderungen (erhalten, postieren, platzieren, löschen), um mit der Datenbank zu interagieren.
  • PHP -Integration: Wir werden mit dem CouchDB -Client von Guzzle und Doktrin nachweisen.
  • Erweiterte Funktionen (kurz erwähnt): MapReduce, Konfliktlösung, Änderung der Feeds.

Erstellen einer Datenbank:

Verwenden Sie Futon ( https://www.php.cn/link/3bbbc60ff463969b78a091ff51AC6566 ), um eine Datenbank zu erstellen. Geben Sie ihm einen Namen (z. B. test_couch).

A Pokemon Crash Course on CouchDB

Nach der Erstellung sehen Sie eine Schnittstelle zum Hinzufügen von Dokumenten. Denken Sie daran, dass Dokumente in CouchDB die grundlegende Einheit sind. Es gibt keine Tische. Sie können verschiedene Datenstrukturen in derselben Datenbank speichern. Für die Organisation geben Sie ein type -Feld ein, um Dokumente zu kategorisieren (z. B. "type": "users").

Beispieldokumentstrukturen:

  • Benutzer: {"id": 123, "fname": "doppo", "lname": "kunikida", "pw": "secret", "hobbies": ["reading", "sleeping"], "type": "users"}
  • Blog -Beitrag: {"title": "The big brown fox", "author": "fox", "text": "...", "publish_date": "2016-07-07", "type": "blog_posts"}

HTTP -API -Wechselwirkung:

Sie können curl oder Tools wie Postman verwenden, um direkt mit der CouchDB HTTP -API zu interagieren.

  • Datenbank erstellen (curl): curl -X PUT http://localhost:5984/<database_name></database_name> (Rückgabe {"ok":true})
  • Dokument erstellen (Postman): Senden Sie eine Postanforderung an http://localhost:5984/test_couch, mit Content-Type: application/json und Ihrem JSON -Dokument im Körper.

A Pokemon Crash Course on CouchDB

Bulk Insert:

Verwenden Sie eine Postanforderung an http://localhost:5984/test_couch/_bulk_docs mit einer Reihe von Dokumenten in der JSON -Körperschaft.

A Pokemon Crash Course on CouchDB

Abzüge Dokumente:

  • Alle Dokumente: http://localhost:5984/test_couch/_all_docs?include_docs=true
  • Spezifisches Dokument: http://localhost:5984/test_couch/<document_id>?include_docs=true</document_id>
  • Spezifische Überarbeitung: add &rev=<revision_id></revision_id> zur URL oben hinzufügen.

CouchDB verfolgt Revisionen; Jedes Update erstellt eine neue Revision. Futon ermöglicht das Durchsuchen dieser Überarbeitungen.

A Pokemon Crash Course on CouchDB

Ansichten (MapReduce):

Ansichten bieten Abfragemöglichkeiten. Erstellen Sie Ansichten in Futon mit MAP und reduzieren Sie Funktionen (JavaScript). Diese Funktionen werden in Entwurfsdokumenten gespeichert.

A Pokemon Crash Course on CouchDB

  • Beispiel -MAP -Funktion (Filter durch Trainer):
function(doc) {
  emit(doc.trainer, doc.name);
}
Nach dem Login kopieren

Zugriffsansichten über URLs wie: http://localhost:5984/test_couch/_design/<design_doc>/_view/<view_name>?key="Ash"

Aktualisieren von Dokumenten:

Senden Sie eine Put -Anfrage an die Dokument -URL, einschließlich des Feldes _rev mit der neuesten Revisions -ID. Sie müssen das gesamte aktualisierte Dokument bereitstellen.

A Pokemon Crash Course on CouchDB

Dokumente löschen:

Senden Sie eine Löschanforderung an die Dokument -URL, einschließlich des Felds _rev mit der neuesten Revisions -ID.

http://localhost:5984/test_couch/<document_id>?rev=<revision_id>

PHP -Integration (Guzzle):

guzzle vereinfacht HTTP -Anforderungen in PHP. Die folgenden Beispiele zeigen grundlegende Vorgänge: (Denken Sie daran, Guzzle zu installieren: composer require guzzlehttp/guzzle)

<?php
require 'vendor/autoload.php';
use GuzzleHttp\Client;

$client = new Client(['base_uri' => 'http://localhost:5984']);

// ... (GET, POST, PUT, DELETE examples using Guzzle similar to the curl and Postman examples above) ...
?>
Nach dem Login kopieren

PHP -Integration (Doktrin -Couchdb -Client):

Der CouchDB-Client von

Doctrine bietet eine höhere Abstraktion. (Installieren Sie mit: composer require doctrine/couchdb)

<?php
require 'vendor/autoload.php';

$client = \Doctrine\CouchDB\CouchDBClient::create(['dbname' => 'test_couch']);

// ... (Examples for creating, retrieving, updating, and deleting documents using the Doctrine client) ...
?>
Nach dem Login kopieren

Schlussfolgerung:

Dieses Tutorial bietet eine praktische Einführung in CouchDB mit seiner HTTP -API und PHP. Erkunden Sie die offizielle Dokumentation und den endgültigen Leitfaden für fortgeschrittenere Funktionen. Zukünftige Beiträge werden tiefer in die Erstellung von Anwendungen mit CouchDB eingehen.

Das obige ist der detaillierte Inhalt vonEin Pokemon -Crashkurs auf CouchDB. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage