Rumah >pembangunan bahagian belakang >tutorial php >Cari pangkalan data graf dengan NEO4J dan PHP

Cari pangkalan data graf dengan NEO4J dan PHP

尊渡假赌尊渡假赌尊渡假赌
尊渡假赌尊渡假赌尊渡假赌asal
2025-02-18 08:38:17595semak imbas

neo4j dan php: gabungan yang kuat untuk pangkalan data graf

NEO4J, pangkalan data grafik terkemuka, cemerlang dalam menguruskan data yang sangat saling berkaitan, menjadikannya sesuai untuk aplikasi yang melibatkan perniagaan, sosial, pengetahuan, minat, dan graf media. Jawatan ini meneroka NEO4J dan menunjukkan penggunaannya dengan PHP. Jawatan berikutnya akan terperinci membina aplikasi grafik yang berkuasa Silex.

Pangkalan data graf adalah penting bagi syarikat yang berurusan dengan hubungan yang kompleks. Fleksibiliti model graf dan grafik 'penyimpanan dan pengambilan semula pangkalan data menjadikan mereka penyelesaian yang kuat. Keupayaan terbukti NEO4J untuk mengendalikan dataset yang besar dan saling berkaitan menjadikannya pilihan utama. Nilainya terbukti dalam aplikasi seperti meningkatkan pengalaman pelanggan dan memudahkan pengeditan peta kompleks.

Pengenalan cepat ke pangkalan data grafik dan neo4j

Grafik terdiri daripada nod (entiti) yang dikaitkan oleh Hubungan . Dalam model graf harta, nod dan hubungan dilabelkan dan boleh mempunyai sifat.

Discover Graph Databases with Neo4j and PHP

imej melalui wikipedia

Pangkalan data graf mengoptimumkan operasi pada data yang disambungkan. Struktur penyimpanan khusus untuk nod dan hubungan memastikan prestasi tinggi, menghapuskan keperluan untuk operasi yang mahal semasa pelaksanaan pertanyaan.

Pertimbangkan aplikasi sosial di mana pengguna mengikuti satu sama lain. Pengguna diwakili sebagai nod dengan label dan sifat.

Discover Graph Databases with Neo4j and PHP Hubungan, dengan jenis dan sifat, menentukan hubungan antara nod, menambah makna semantik kepada data.

Perwakilan visual data ini secara semulajadi meminjamkan dirinya kepada pangkalan data graf. Discover Graph Databases with Neo4j and PHP

cypher: bahasa pertanyaan neo4j Discover Graph Databases with Neo4j and PHP

Neo4J menggunakan Cypher, bahasa pertanyaan deklaratif yang menekankan kebolehbacaan dan ekspresi. Cypher memberi tumpuan kepada apa untuk mengambil, bukan

bagaimana

. Klausa utama termasuk: : Cari corak graf.

  • : hasil penapis. MATCH
  • : Menentukan format output. WHERE
  • : mewujudkan nod dan hubungan. RETURN
  • : Memadankan corak sedia ada atau mencipta yang baru. CREATE
  • Cypher menggunakan tanda kurung untuk nod (mis., MERGE) dan anak panah untuk hubungan (mis.,
  • atau
).

(m:Movie) pertanyaan untuk mengambil Hannah Hilpert dan pengikutnya: -->

<code class="language-cypher">MATCH (user:User {name:'Hannah Hilpert'})-[r:FOLLOWS]->(follower)
RETURN user, follower</code>

Discover Graph Databases with Neo4j and PHP

neo4j dan php

NEO4J berjalan sebagai pelayan dengan API HTTP yang boleh diakses untuk menanyakan dan memanipulasi data. Anda boleh memuat turun neo4j dari

https://www.php.cn/link/25989f1da5598dd89e7134affeca8697 atau gunakan perkhidmatan seperti graphenedb. Penyemak imbas NEO4J ( https://www.php.cn/link/0806A60E2E5466094AB2652BEF28A251 ) menyediakan antara muka visual. komponen neoxygen

Neoxygen menawarkan komponen PHP sumber terbuka untuk berinteraksi dengan NEO4J. menyediakan pelanggan yang mantap untuk API HTTP NEO4J.

Pemasangan dan Konfigurasi NeoClient

tambahkan kebergantungan ke anda:

neoclient Konfigurasikan sambungan: composer.json

Untuk graphenedb, gunakan sambungan yang selamat:
<code class="language-json">{
  "require": {
    "neoxygen/neoclient":"~2.1"
  }
}</code>

Dayakan pemformatan respons automatik:
<code class="language-php">use Neoxygen\NeoClient\ClientBuilder;

$client = ClientBuilder::create()
  ->addConnection('default', 'http', 'localhost', 7474)
  ->build();</code>

<code class="language-php"><?php
use Neoxygen\NeoClient\ClientBuilder;

$connUrl = parse_url('http://master.sb02.stations.graphenedb.com:24789/db/data/');
$user = 'master';
$pwd = 's3cr3tP@ssw0rd';

$client = ClientBuilder::create()
  ->addConnection('default', $connUrl['scheme'], $connUrl['host'], $connUrl['port'], true, $user, $password)
  ->build();</code>
Membina aplikasi sampel

<code class="language-php">$client = ClientBuilder::create()
  ->addConnection('default', 'http', 'localhost', 7474)
  ->setAutoFormatResponse(true)
  ->build();</code>
mari kita buat pengguna dan

hubungan. A pertanyaan:

FOLLOWS CREATE kod php untuk membuat pengguna:

<code class="language-cypher">CREATE (user:User {name:'Kenneth'}) RETURN user</code>

Mewujudkan hubungan: Discover Graph Databases with Neo4j and PHP

<code class="language-php">$query = 'CREATE (user:User {name:"Kenneth"}) RETURN user';
$result = $client->sendCypherQuery($query)->getResult();
$user = $result->getSingleNode();
$name = $user->getProperty('name');</code>
menggunakan GraphGen untuk membuat pelbagai pengguna dan hubungan memudahkan proses. Import graf yang dihasilkan ke dalam pangkalan data anda.

<code class="language-php">$query = 'MATCH (user1:User {name:{name1}}), (user2:User {name:{name2}}) CREATE (user1)-[:FOLLOWS]->(user2)';
$params = ['name1' => 'Kenneth', 'name2' => 'Maxime'];
$client->sendCypherQuery($query, $params);</code>

pertanyaan cypher untuk cadangan persahabatan: Discover Graph Databases with Neo4j and PHP

Discover Graph Databases with Neo4j and PHP Kesimpulan

Jawatan ini memperkenalkan pangkalan data graf, NEO4J, dan Cypher, menunjukkan cara menggunakan NEO4J dengan PHP. Jawatan seterusnya akan membina aplikasi Silex yang lengkap. Soalan Lazim yang disediakan menawarkan butiran lanjut dan amalan terbaik.
<code class="language-cypher">MATCH (user:User {firstname: {firstname}})-[:FOLLOWS]->(followed)-[:FOLLOWS]->(suggestion)
WHERE user <> suggestion
  AND NOT (user)-[:FOLLOWS]->(suggestion)
RETURN user, suggestion, count(*) as occurrence
ORDER BY occurrence DESC
LIMIT 10</code>

Atas ialah kandungan terperinci Cari pangkalan data graf dengan NEO4J dan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn