Neo4j - Panduan Cepat
Neo4j adalah Database Grafik open source terkemuka di dunia yang dikembangkan menggunakan teknologi Java. Ini sangat skalabel dan bebas skema (NoSQL).
Apa itu Database Grafik?
Grafik adalah representasi bergambar dari sekumpulan objek di mana beberapa pasang objek dihubungkan oleh tautan. Ini terdiri dari dua elemen - node (simpul) dan hubungan (tepi).
Database grafik adalah database yang digunakan untuk memodelkan data yang berupa grafik. Di sini, node dari grafik menggambarkan entitas sedangkan hubungan menggambarkan asosiasi node ini.
Database Grafik Populer
Neo4j adalah Database Grafik yang populer. Database Grafik lainnya adalah Oracle NoSQL Database, OrientDB, HypherGraphDB, GraphBase, InfiniteGraph, dan AllegroGraph.
Mengapa Database Grafik?
Saat ini, sebagian besar data ada dalam bentuk hubungan antar objek yang berbeda dan lebih sering, hubungan antar data lebih berharga daripada data itu sendiri.
Database relasional menyimpan data yang sangat terstruktur yang memiliki beberapa record yang menyimpan jenis data yang sama sehingga dapat digunakan untuk menyimpan data terstruktur dan, tidak menyimpan hubungan antar data.
Tidak seperti database lain, database grafik menyimpan hubungan dan koneksi sebagai entitas kelas satu.
Model data untuk database grafik lebih sederhana dibandingkan dengan database lain dan dapat digunakan dengan sistem OLTP. Mereka menyediakan fitur seperti integritas transaksional dan ketersediaan operasional.
Database Grafik RDBMS Vs
Berikut adalah tabel yang membandingkan database Relasional dan database Graph.
Sr Tidak | RDBMS | Database Grafik |
---|---|---|
1 | Tabel | Grafik |
2 | Baris | Node |
3 | Kolom dan Data | Properti dan nilainya |
4 | Kendala | Hubungan |
5 | Bergabung | Traversal |
Keuntungan Neo4j
Berikut adalah keunggulan dari Neo4j.
Flexible data model - Neo4j menyediakan model data sederhana yang fleksibel namun kuat, yang dapat dengan mudah diubah sesuai dengan aplikasi dan industri.
Real-time insights - Neo4j memberikan hasil berdasarkan data real-time.
High availability - Neo4j sangat tersedia untuk aplikasi real-time perusahaan besar dengan jaminan transaksional.
Connected and semi structures data - Dengan Neo4j, Anda dapat dengan mudah merepresentasikan data yang terhubung dan semi-terstruktur.
Easy retrieval - Dengan menggunakan Neo4j, Anda tidak hanya dapat mewakili tetapi juga dengan mudah mengambil (melintasi / menavigasi) data yang terhubung lebih cepat jika dibandingkan dengan database lain.
Cypher query language- Neo4j menyediakan bahasa kueri deklaratif untuk merepresentasikan grafik secara visual, menggunakan sintaks ascii-art. Perintah bahasa ini dalam format yang dapat dibaca manusia dan sangat mudah dipelajari.
No joins - Menggunakan Neo4j, TIDAK memerlukan gabungan yang kompleks untuk mengambil data yang terhubung / terkait karena sangat mudah untuk mengambil node yang berdekatan atau detail hubungan tanpa gabungan atau indeks.
Fitur Neo4j
Berikut adalah fitur-fitur penting dari Neo4j -
Data model (flexible schema)- Neo4j mengikuti model data bernama model grafik properti asli. Di sini, grafik berisi node (entitas) dan node tersebut terhubung satu sama lain (digambarkan oleh hubungan). Node dan hubungan menyimpan data dalam pasangan nilai-kunci yang dikenal sebagai properti.
Di Neo4j, tidak perlu mengikuti skema tetap. Anda dapat menambah atau menghapus properti sesuai kebutuhan. Ini juga menyediakan batasan skema.
ACID properties - Neo4j mendukung aturan ACID (Atomicity, Consistency, Isolation, dan Durability) penuh.
Scalability and reliability- Anda dapat menskalakan database dengan meningkatkan jumlah baca / tulis, dan volume tanpa memengaruhi kecepatan pemrosesan kueri dan integritas data. Neo4j juga menyediakan dukungan untukreplication untuk keamanan dan keandalan data.
Cypher Query Language- Neo4j menyediakan bahasa kueri deklaratif yang kuat yang dikenal sebagai Cypher. Ini menggunakan seni ASCII untuk menggambarkan grafik. Cypher mudah dipelajari dan dapat digunakan untuk membuat dan mengambil hubungan antar data tanpa menggunakan kueri kompleks seperti Bergabung.
Built-in web application - Neo4j menyediakan built-in Neo4j Browseraplikasi web. Menggunakan ini, Anda dapat membuat dan menanyakan data grafik Anda.
Drivers - Neo4j dapat bekerja dengan -
REST API untuk bekerja dengan bahasa pemrograman seperti Java, Spring, Scala dll.
Java Script untuk bekerja dengan framework UI MVC seperti Node JS.
Ini mendukung dua jenis Java API: Cypher API dan Native Java API untuk mengembangkan aplikasi Java. Selain itu, Anda juga dapat bekerja dengan database lain seperti MongoDB, Cassandra, dll.
Indexing - Neo4j mendukung Indeks dengan menggunakan Apache Lucence.
Model Data Grafik Properti Neo4j
Database Grafik Neo4j mengikuti Model Grafik Properti untuk menyimpan dan mengelola datanya.
Berikut adalah fitur utama dari Model Grafik Properti -
Model merepresentasikan data dalam Nodes, Relationships dan Properties
Properti adalah pasangan nilai kunci
Node direpresentasikan menggunakan lingkaran dan Hubungan direpresentasikan menggunakan tombol panah
Hubungan memiliki arah: Searah dan Dua Arah
Setiap Relasi berisi "Start Node" atau "From Node" dan "To Node" atau "End Node"
Baik Node maupun Relasi berisi properti
Hubungan menghubungkan node
Dalam Model Data Grafik Properti, hubungan harus terarah. Jika kita mencoba membuat hubungan tanpa arah, maka akan muncul pesan error.
Di Neo4j juga, hubungan harus terarah. Jika kita mencoba membuat hubungan tanpa arah, maka Neo4j akan mengeluarkan pesan kesalahan yang mengatakan bahwa "Hubungan harus terarah".
Database Grafik Neo4j menyimpan semua datanya dalam Node dan Hubungan. Kami tidak memerlukan RRBMS Database tambahan atau database SQL apa pun untuk menyimpan data database Neo4j. Ini menyimpan datanya dalam bentuk Grafik dalam format aslinya.
Neo4j menggunakan Native GPE (Mesin Pemroses Grafik) untuk bekerja dengan format penyimpanan grafik Asli.
Blok bangunan utama Model Data Graph DB adalah -
- Nodes
- Relationships
- Properties
Berikut ini adalah contoh sederhana dari Grafik Properti.
Di sini, kami telah merepresentasikan Node menggunakan Lingkaran. Hubungan direpresentasikan menggunakan Panah. Hubungan bersifat terarah. Kita dapat merepresentasikan data Node dalam bentuk Properti (pasangan nilai kunci). Dalam contoh ini, kami telah mewakili setiap properti Id Node di dalam Lingkaran Node.
Pada bab ini, kita akan membahas cara menginstal Neo4j di sistem Anda menggunakan file exe.
Neo4j Database Server Setup dengan File Windows exe
Ikuti langkah-langkah yang diberikan di bawah ini untuk mengunduh Neo4j ke sistem Anda.
Step 1 - Kunjungi situs resmi Neo4j menggunakan https://neo4j.com/. Saat mengklik, tautan ini akan membawa Anda ke beranda situs web neo4j.
Step 2- Seperti yang disorot pada tangkapan layar di atas, laman ini memiliki tombol Unduh di sisi kanan atas. Klik itu.
Step 3- Ini akan mengarahkan Anda ke halaman unduhan, di mana Anda dapat mengunduh edisi komunitas dan edisi perusahaan dari Neo4j. Unduh perangkat lunak edisi komunitas dengan mengklik tombol yang sesuai.
Step 4- Ini akan membawa Anda ke halaman di mana Anda dapat mengunduh versi komunitas perangkat lunak Neo4j yang kompatibel dengan sistem operasi yang berbeda. Unduh file masing-masing ke sistem operasi yang diinginkan.
Ini akan mengunduh file bernama neo4j-community_windows-x64_3_1_1.exe ke sistem Anda seperti yang ditunjukkan pada tangkapan layar berikut.
Step 5 - Klik dua kali file exe untuk menginstal Neo4j Server.
Step 6- Terima perjanjian lisensi dan lanjutkan penginstalan. Setelah menyelesaikan proses, Anda dapat mengamati bahwa Neo4j diinstal di sistem Anda.
Memulai Server
Step 1 - Klik menu start Windows dan mulai server Neo4j dengan mengklik pintasan menu mulai untuk Neo4j.
Step 2- Saat mengklik pintasan, Anda akan melihat jendela untuk edisi Neo4j Community. Secara default, ini memilih c: \ Users \ [username] \ Documents \ Neo4j \ default.graphdb. Jika mau, Anda dapat mengubah jalur Anda ke direktori lain.
Step 3 - Klik tombol "Start" untuk memulai server Neo4j.
Setelah server dimulai, Anda dapat mengamati bahwa direktori database diisi seperti yang ditunjukkan pada gambar layar berikut.
Bekerja dengan Neo4j
Seperti yang telah dibahas di bab sebelumnya, neo4j menyediakan aplikasi penjelajahan bawaan untuk bekerja dengan Neo4j. Anda dapat mengakses Neo4j menggunakan URLhttp://localhost:7474/
Database Grafik Neo4j memiliki blok bangunan berikut -
- Nodes
- Properties
- Relationships
- Labels
- Browser Data
Node
Node adalah unit fundamental dari sebuah Graph. Ini berisi properti dengan pasangan nilai kunci seperti yang ditunjukkan pada gambar berikut.
Di sini, Node Name = "Employee" dan ini berisi sekumpulan properti sebagai pasangan nilai kunci.
Properti
Properti adalah pasangan nilai-kunci untuk mendeskripsikan Grafik Node dan Hubungan.
Key = Value
Dimana Kunci adalah String dan Nilai dapat direpresentasikan menggunakan tipe Data Neo4j apa pun.
Hubungan
Hubungan adalah blok bangunan utama lainnya dari Database Grafik. Ini menghubungkan dua node seperti yang digambarkan pada gambar berikut.
Di sini, Emp dan Dept adalah dua node yang berbeda. "WORKS_FOR" adalah hubungan antara node Emp dan Dept.
Seperti yang ditunjukkan, tanda panah dari Emp ke Dept, hubungan ini menjelaskan -
Emp WORKS_FOR Dept
Setiap hubungan berisi satu simpul awal dan satu simpul akhir.
Di sini, "Emp" adalah node awal, dan "Dept" adalah node akhir.
Karena tanda panah hubungan ini mewakili hubungan dari node "Emp" ke node "Dept", hubungan ini dikenal sebagai node "Incoming Relationship" ke "Dept" dan "Outgoing Relationship" ke node "Emp".
Seperti node, hubungan juga dapat berisi properti sebagai key-value pair.
Di sini, hubungan "WORKS_FOR" memiliki satu properti sebagai pasangan nilai kunci.
Id = 123
Ini mewakili Id dari hubungan ini.
Label
Label mengaitkan nama umum ke sekumpulan node atau hubungan. Node atau hubungan dapat berisi satu atau lebih label. Kita dapat membuat label baru ke node atau hubungan yang sudah ada. Kami dapat menghapus label yang ada dari node atau hubungan yang ada.
Dari diagram sebelumnya, kita dapat mengamati bahwa terdapat dua node.
Node sisi kiri memiliki Label: "Emp" dan node sisi kanan memiliki Label: "Dept".
Hubungan kedua node tersebut juga memiliki Label: "WORKS_FOR".
Note - Neo4j menyimpan data di Properties of Nodes atau Relationships.
Browser Data Neo4j
Setelah kami menginstal Neo4j, kami dapat mengakses Neo4j Data Browser menggunakan URL berikut
http://localhost:7474/browser/
Neo4j Data Browser digunakan untuk menjalankan perintah CQL dan melihat hasilnya.
Di sini, kita perlu menjalankan semua perintah CQL pada prompt dollar: "$"
Ketik perintah setelah simbol dolar dan klik tombol "Jalankan" untuk menjalankan perintah Anda.
Ini berinteraksi dengan Neo4j Database Server, mengambil dan menampilkan hasil tepat di bawah prompt dolar.
Gunakan tombol "Tampilan VI" untuk melihat hasil dalam format diagram. Diagram di atas menunjukkan hasil dalam format "Tampilan UI".
Gunakan tombol "Tampilan Kisi" untuk melihat hasil dalam Tampilan Kisi. Diagram berikut menunjukkan hasil yang sama dalam format "Tampilan Kisi".
Saat kami menggunakan "Tampilan Kisi" untuk melihat hasil Kueri, kami dapat mengekspornya ke dalam file dalam dua format berbeda.
CSV
Klik tombol "Ekspor CSV" untuk mengekspor hasil dalam format file csv.
JSON
Klik tombol "Ekspor JSON" untuk mengekspor hasil dalam format file JSON.
Namun, jika kita menggunakan "Tampilan UI" untuk melihat hasil Query kita, kita dapat mengekspornya menjadi file hanya dalam satu format: JSON
CQL adalah singkatan dari Cypher Query Language. Seperti Oracle Database memiliki bahasa kueri SQL, Neo4j memiliki CQL sebagai bahasa kueri.
Neo4j CQL
- Adalah bahasa query untuk Database Grafik Neo4j.
- Adalah bahasa pencocokan pola deklaratif.
- Mengikuti SQL seperti sintaks.
- Sintaksnya sangat sederhana dan dalam format yang dapat dibaca manusia.
Seperti Oracle SQL
Neo4j CQL memiliki perintah untuk melakukan operasi Database.
Neo4j CQL mendukung banyak klausa seperti WHERE, ORDER BY, dll., Untuk menulis kueri yang sangat kompleks dengan cara yang mudah.
Neo4j CQL mendukung beberapa fungsi seperti String, Agregasi. Selain itu, ini juga mendukung beberapa Fungsi Hubungan.
Klausul Neo4j CQL
Berikut adalah klausul baca dari Neo4j Cypher Query Lpenderitaan -
Sr Tidak | Baca Klausul | Pemakaian |
---|---|---|
1 | PERTANDINGAN | Klausa ini digunakan untuk mencari data dengan pola tertentu. |
2 | PERTANDINGAN OPSIONAL | Ini sama dengan pencocokan, satu-satunya perbedaan adalah ia dapat menggunakan null jika ada bagian pola yang hilang. |
3 | DIMANA | Id klausa ini digunakan untuk menambahkan konten ke kueri CQL. |
4 | MULAILAH | Klausul ini digunakan untuk menemukan titik awal melalui indeks warisan. |
5 | BEBAN CSV | Klausul ini digunakan untuk mengimpor data dari file CSV. |
Berikut adalah klausul tulis dari Neo4j Cypher Query Lpenderitaan -
Sr Tidak | Tulis Klausul | Pemakaian |
---|---|---|
1 | MEMBUAT | Klausa ini digunakan untuk membuat node, hubungan, dan properti. |
2 | MENGGABUNGKAN | Klausul ini memverifikasi apakah pola yang ditentukan ada dalam grafik. Jika tidak, itu menciptakan polanya. |
3 | SET | Klausa ini digunakan untuk memperbarui label pada node, properti pada node dan hubungan. |
4 | MENGHAPUS | Klausa ini digunakan untuk menghapus node dan hubungan atau jalur, dll. Dari grafik. |
5 | MENGHAPUS | Klausa ini digunakan untuk menghapus properti dan elemen dari node dan hubungan. |
6 | UNTUK SETIAP | Kelas ini digunakan untuk memperbarui data dalam daftar. |
7 | BUAT UNIK | Menggunakan klausa CREATE dan MATCH, Anda bisa mendapatkan pola unik dengan mencocokkan pola yang ada dan membuat yang hilang. |
8 | Mengimpor file CSV dengan Cypher | Menggunakan Load CSV, Anda dapat mengimpor data dari file .csv. |
Berikut adalah klausul umum Neo4j Cypher Query Lpenderitaan -
Sr Tidak | Klausul Umum | Pemakaian |
---|---|---|
1 | KEMBALI | Klausa ini digunakan untuk menentukan apa yang harus disertakan dalam kumpulan hasil kueri. |
2 | DIPESAN OLEH | Klausa ini digunakan untuk mengatur keluaran kueri secara berurutan. Ini digunakan bersama dengan klausaRETURN atau WITH. |
3 | MEMBATASI | Klausa ini digunakan untuk membatasi baris dalam hasil ke nilai tertentu. |
4 | MELEWATKAN | Klausa ini digunakan untuk menentukan dari baris mana untuk memulai termasuk baris dalam keluaran. |
5 | DENGAN | Klausa ini digunakan untuk menyatukan bagian kueri. |
6 | BERISTIRAHAT | Klausa ini digunakan untuk memperluas daftar menjadi urutan baris. |
7 | PERSATUAN | Klausa ini digunakan untuk menggabungkan hasil dari beberapa query. |
8 | PANGGILAN | Klausa ini digunakan untuk menjalankan prosedur yang digunakan dalam database. |
Fungsi Neo4j CQL
Berikut ini adalah Fungsi Neo4j CQL yang sering digunakan -
Sr Tidak | Fungsi CQL | Pemakaian |
---|---|---|
1 | Tali | Mereka digunakan untuk bekerja dengan literal String. |
2 | Pengumpulan | Mereka digunakan untuk melakukan beberapa operasi agregasi pada hasil Query CQL. |
3 | Hubungan | Mereka digunakan untuk mendapatkan detail hubungan seperti startnode, endnode, dll. |
Kami akan membahas semua perintah Neo4j CQL, klausa dan fungsi sintaks, penggunaan dan contoh secara rinci di bab-bab berikutnya.
Jenis Data Neo4j CQL
Tipe data ini mirip dengan bahasa Java. Mereka digunakan untuk mendefinisikan properti node atau hubungan.
Neo4j CQL mendukung tipe data berikut -
Sr Tidak | Jenis Data CQL | Pemakaian |
---|---|---|
1 | Boolean | Ini digunakan untuk mewakili literal Boolean: benar, salah. |
2 | byte | Ini digunakan untuk mewakili bilangan bulat 8-bit. |
3 | pendek | Ini digunakan untuk mewakili bilangan bulat 16-bit. |
4 | int | Ini digunakan untuk mewakili bilangan bulat 32-bit. |
5 | panjang | Ini digunakan untuk mewakili bilangan bulat 64-bit. |
6 | mengapung | Ini digunakan untuk mewakili angka floating-point 32-bit. |
7 | dua kali lipat | Ini digunakan untuk mewakili angka floating-point 64-bit. |
8 | arang | Ini digunakan untuk mewakili karakter 16-bit. |
9 | Tali | Ini digunakan untuk mewakili String. |
Operator CQL
Berikut adalah daftar operator yang didukung oleh Neo4j Cypher Query language.
Sr Tidak | Tipe | Operator |
---|---|---|
1 | Matematis | +, -, *, /,%, ^ |
2 | Perbandingan | +, <>, <,>, <=,> = |
3 | Boolean | DAN, ATAU, XOR, TIDAK |
4 | Tali | + |
5 | Daftar | +, IN, [X], [X… ..Y] |
6 | Ekspresi Reguler | = - |
7 | Pencocokan string | MULAI DENGAN, AKHIR DENGAN, BATAS |
Operator Boolean di Neo4j CQL
Neo4j mendukung operator Boolean berikut untuk digunakan dalam klausa Neo4j CQL WHERE untuk mendukung berbagai kondisi.
Sr Tidak | Operator Boolean | Deskripsi |
---|---|---|
1 | DAN | Ini adalah kata kunci Neo4j CQL untuk mendukung operasi AND. Ini seperti operator SQL AND. |
2 | ATAU | Ini adalah kata kunci Neo4j CQL untuk mendukung operasi OR. Ini seperti operator SQL AND. |
3 | TIDAK | Ini adalah kata kunci Neo4j CQL untuk mendukung operasi NOT. Ini seperti operator SQL AND. |
4 | XOR | Ini adalah kata kunci Neo4j CQL untuk mendukung operasi XOR. Ini seperti operator SQL AND. |
Operator Perbandingan di Neo4j CQL
Neo4j mendukung operator Perbandingan berikut untuk digunakan dalam klausa Neo4j CQL WHERE untuk mendukung kondisi.
Sr Tidak | Operator Boolean | Deskripsi |
---|---|---|
1 | = | Ini adalah operator "Sama Dengan" Neo4j CQL. |
2 | <> | Ini adalah operator Neo4j CQL "Not Equal To". |
3 | < | Ini adalah operator "Less Than" Neo4j CQL. |
4 | > | Ini adalah operator "Greater Than" Neo4j CQL. |
5 | <= | Ini adalah operator Neo4j CQL "Kurang Dari Atau Sama Dengan". |
6 | > = | Ini adalah operator "Lebih Besar Dari Atau Sama Dengan" Neo4j CQL. |
Seperti yang telah dibahas, node adalah data / record dalam database grafik. Anda dapat membuat node di Neo4j menggunakanCREATEayat. Bab ini mengajari Anda cara -
- Buat satu node
- Buat banyak node
- Buat node dengan label
- Buat node dengan banyak label
- Buat node dengan properti
- Mengembalikan node yang dibuat
Membuat simpul tunggal
Anda dapat membuat node di Neo4j hanya dengan menentukan nama node yang akan dibuat bersama dengan klausa CREATE.
Sintaksis
Berikut ini adalah sintaks untuk membuat node menggunakan Bahasa Query Cypher.
CREATE (node_name);
Note - Titik koma (;) adalah opsional.
Contoh
Berikut ini adalah contoh Permintaan Cypher yang membuat sebuah node di Neo4j.
CREATE (sample)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1 - Buka Aplikasi desktop Neo4j dan mulai Server Neo4j seperti yang ditunjukkan pada gambar berikut.
Step 2 - Buka browser Anda, salin tempel URL berikut di bilah alamat Anda http://localhost:7474/. Ini akan memberi Anda aplikasi browser bawaan Neo4j dengan prompt dolar seperti yang ditunjukkan pada tangkapan layar berikut.
Step 3 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Verifikasi
Untuk memverifikasi pembuatan jenis node, jalankan kueri berikut di prompt dollar.
MATCH (n) RETURN n
Kueri ini mengembalikan semua node dalam database (kita akan membahas kueri ini secara mendetail di bab-bab selanjutnya).
Saat menjalankan, kueri ini menunjukkan simpul yang dibuat seperti yang ditunjukkan pada tangkapan layar berikut.
Membuat Banyak Node
Klausa create Neo4j CQL juga digunakan untuk membuat banyak node pada saat yang bersamaan. Untuk melakukannya, Anda harus meneruskan nama node yang akan dibuat, dipisahkan dengan koma.
Sintaksis
Berikut sintaks untuk membuat beberapa node menggunakan klausa CREATE.
CREATE (node1),(node2)
Contoh
Berikut adalah contoh Permintaan Cypher yang membuat beberapa node di Neo4j.
CREATE (sample1),(sample2)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Verifikasi
Untuk memverifikasi pembuatan node, ketik dan jalankan kueri berikut di prompt dollar.
MATCH (n) RETURN n
Kueri ini mengembalikan semua node dalam database (kita akan membahas kueri ini secara mendetail di bab-bab selanjutnya).
Saat menjalankan, kueri ini menunjukkan simpul yang dibuat seperti yang ditunjukkan pada tangkapan layar berikut.
Membuat Node dengan Label
Label di Neo4j digunakan untuk mengelompokkan (mengklasifikasikan) node menggunakan label. Anda dapat membuat label untuk node di Neo4j menggunakan klausa CREATE.
Sintaksis
Berikut sintaks untuk membuat node dengan label menggunakan Cypher Query Language.
CREATE (node:label)
Contoh
Berikut adalah contoh Query Cypher yang membuat node dengan label.
CREATE (Dhawan:player)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Verifikasi
Untuk memverifikasi pembuatan node, ketik dan jalankan kueri berikut di prompt dollar.
MATCH (n) RETURN n
Kueri ini mengembalikan semua node dalam database (kita akan membahas kueri ini secara mendetail di bab-bab selanjutnya).
Saat menjalankan, kueri ini menunjukkan simpul yang dibuat seperti yang ditunjukkan pada tangkapan layar berikut.
Membuat Node dengan Banyak Label
Anda juga dapat membuat beberapa label untuk satu node. Anda perlu menentukan label untuk node dengan memisahkannya dengan titik dua ":".
Sintaksis
Berikut sintaks untuk membuat node dengan beberapa label.
CREATE (node:label1:label2:. . . . labeln)
Contoh
Berikut adalah contoh Permintaan Cypher yang membuat node dengan beberapa label di Neo4j.
CREATE (Dhawan:person:player)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Verifikasi
Untuk memverifikasi pembuatan node, ketik dan jalankan kueri berikut di prompt dollar.
MATCH (n) RETURN n
Kueri ini mengembalikan semua node dalam database (kita akan membahas kueri ini secara mendetail di bab-bab selanjutnya).
Saat menjalankan, kueri ini menunjukkan simpul yang dibuat seperti yang ditunjukkan pada tangkapan layar berikut.
Buat Node dengan Properties
Properti adalah pasangan nilai kunci yang digunakan node untuk menyimpan data. Anda dapat membuat node dengan properti menggunakan klausa CREATE. Anda perlu menentukan properti ini dipisahkan dengan koma di dalam kurung kurawal "{}".
Sintaksis
Berikut sintaks untuk membuat node dengan properti.
CREATE (node:label { key1: value, key2: value, . . . . . . . . . })
Contoh
Berikut adalah contoh Permintaan Cypher yang membuat node dengan properti.
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"})
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Verifikasi
Untuk memverifikasi pembuatan node, ketik dan jalankan kueri berikut di prompt dollar.
MATCH (n) RETURN n
Kueri ini mengembalikan semua node dalam database (kita akan membahas kueri ini secara mendetail di bab-bab selanjutnya).
Saat menjalankan, kueri ini menunjukkan simpul yang dibuat seperti yang ditunjukkan pada tangkapan layar berikut.
Mengembalikan Node yang Dibuat
Sepanjang bab ini, kami menggunakan MATCH (n) RETURN nquery untuk melihat node yang dibuat. Kueri ini mengembalikan semua node yang ada di database.
Alih-alih ini, kita dapat menggunakan klausa RETURN dengan CREATE untuk melihat node yang baru dibuat.
Sintaksis
Berikut ini adalah sintaks untuk mengembalikan node di Neo4j.
CREATE (Node:Label{properties. . . . }) RETURN Node
Contoh
Berikut adalah contoh Permintaan Cypher yang membuat node dengan properti dan mengembalikannya.
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"}) RETURN Dhawan
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Dalam Noe4j, hubungan adalah elemen yang digunakan untuk menghubungkan dua node pada grafik. Hubungan ini memiliki arah, jenis, dan pola bentuk datanya. Bab ini mengajari Anda cara -
- Ciptakan hubungan
- Buat hubungan antara node yang ada
- Buat hubungan dengan label dan properti
Menciptakan Hubungan
Kita dapat membuat hubungan menggunakan klausa CREATE. Kami akan menentukan hubungan dalam tanda kurung siku "[]" tergantung pada arah hubungan itu ditempatkan antara tanda hubung "-" dan panah "→" seperti yang ditunjukkan dalam sintaks berikut.
Sintaksis
Berikut ini adalah sintaks untuk membuat hubungan menggunakan klausa CREATE.
CREATE (node1)-[:RelationshipType]->(node2)
Contoh
Pertama-tama buat dua node Ind dan Dhawan di database, seperti gambar di bawah ini.
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"})
CREATE (Ind:Country {name: "India"})
Sekarang, buat hubungan bernama BATSMAN_OF antara dua node ini sebagai -
CREATE (Dhawan)-[r:BATSMAN_OF]->(Ind)
Terakhir, kembalikan kedua node untuk melihat hubungan yang dibuat.
RETURN Dhawan, Ind
Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Membuat Hubungan Antar Node yang Ada
Anda juga dapat membuat hubungan antara node yang ada menggunakan MATCH ayat.
Sintaksis
Berikut adalah sintaks untuk membuat hubungan menggunakan klausa MATCH.
MATCH (a:LabeofNode1), (b:LabeofNode2)
WHERE a.name = "nameofnode1" AND b.name = " nameofnode2"
CREATE (a)-[: Relation]->(b)
RETURN a,b
Contoh
Berikut ini adalah contoh Permintaan Cypher yang membuat hubungan menggunakan klausa kecocokan.
MATCH (a:player), (b:Country) WHERE a.name = "Shikar Dhawan" AND b.name = "India"
CREATE (a)-[r: BATSMAN_OF]->(b)
RETURN a,b
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut.
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Membuat Hubungan dengan Label dan Properti
Anda dapat membuat hubungan dengan label dan properti menggunakan klausa CREATE.
Sintaksis
Berikut adalah sintaks untuk membuat hubungan dengan label dan properti menggunakan klausa CREATE.
CREATE (node1)-[label:Rel_Type {key1:value1, key2:value2, . . . n}]-> (node2)
Contoh
Berikut ini adalah contoh Permintaan Cypher yang membuat hubungan dengan label dan properti.
MATCH (a:player), (b:Country) WHERE a.name = "Shikar Dhawan" AND b.name = "India"
CREATE (a)-[r:BATSMAN_OF {Matches:5, Avg:90.75}]->(b)
RETURN a,b
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Membuat Path Lengkap
Di Neo4j, jalur dibentuk menggunakan hubungan berkelanjutan. Path dapat dibuat menggunakan klausa create.
Sintaksis
Berikut ini adalah sintaks untuk membuat jalur di Neo4j menggunakan klausa CREATE.
CREATE p = (Node1 {properties})-[:Relationship_Type]->
(Node2 {properties})[:Relationship_Type]->(Node3 {properties})
RETURN p
Contoh
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Perintah MERGE merupakan gabungan dari perintah CREATE dan perintah MATCH.
Perintah Neo4j CQL MERGE mencari pola tertentu dalam grafik. Jika ada, maka hasilnya akan dikembalikan.
Jika TIDAK ada dalam grafik, maka itu membuat simpul / hubungan baru dan mengembalikan hasilnya.
Dalam bab ini Anda akan belajar bagaimana -
- Gabungkan node dengan label
- Gabungkan node dengan properti
- OnCreate dan OnMatch
- Gabungkan hubungan
Sintaksis
Berikut ini adalah sintaks untuk perintah MERGE.
MERGE (node: label {properties . . . . . . . })
Sebelum melanjutkan ke contoh di bagian ini, buat dua node di database dengan label Dhawan dan Ind. Buat hubungan tipe “BATSMAN_OF” dari Dhawan ke Ind seperti yang ditunjukkan di bawah ini.
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"})
CREATE (Ind:Country {name: "India"})
CREATE (Dhawan)-[r:BATSMAN_OF]->(Ind)
Menggabungkan Node dengan Label
Anda dapat menggabungkan node dalam database berdasarkan label menggunakan klausa MERGE. Jika Anda mencoba menggabungkan node berdasarkan label, maka Neo4j memverifikasi apakah ada node dengan label yang diberikan. Jika tidak, node saat ini akan dibuat.
Sintaksis
Berikut ini sintaks untuk menggabungkan node berdasarkan label.
MERGE (node:label) RETURN node
Contoh 1
Berikut adalah contoh Query Cypher yang menggabungkan node ke Neo4j (berdasarkan label). Saat Anda menjalankan kueri ini, Neo4j memverifikasi apakah ada node dengan labelplayer. Jika tidak, itu membuat node bernama "Jadeja" dan mengembalikannya.
Jika, ada node dengan label yang diberikan, Neo4j mengembalikan semuanya.
MERGE (Jadeja:player) RETURN Jadeja
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Karena Anda telah membuat node bernama "Dhawan" dengan label "player" di database, Neo4j mengembalikannya seperti yang ditunjukkan pada screenshot berikut.
Contoh 2
Sekarang, coba gabungkan node bernama "CT2013" dengan label bernama Turnamen. Karena tidak ada node dengan label ini, Neo4j membuat node dengan nama yang diberikan dan mengembalikannya.
MERGE (CT2013:Tournament{name: "ICC Champions Trophy 2013"})
RETURN CT2013, labels(CT2013)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan Mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Seperti yang telah dibahas, karena tidak ada node dengan label yang diberikan (Turnamen). Neo4j membuat dan mengembalikan node yang ditentukan seperti yang ditunjukkan pada gambar layar berikut.
Menggabungkan Node dengan Properti
Anda juga dapat menggabungkan node dengan sekumpulan properti. Jika Anda melakukannya, Neo4j mencari kecocokan yang sama untuk node yang ditentukan, termasuk propertinya. Jika tidak menemukannya, itu membuatnya.
Sintaksis
Berikut sintaks untuk menggabungkan node menggunakan properti.
MERGE (node:label {key1:value, key2:value, key3:value . . . . . . . . })
Contoh
Berikut adalah contoh Permintaan Cypher untuk menggabungkan node menggunakan properti. Query ini mencoba untuk menggabungkan node bernama “jadeja” menggunakan properti dan label. Karena tidak ada node dengan label dan properti yang tepat, Neo4j membuatnya.
MERGE (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
RETURN Jadeja
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan Mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Seperti yang telah dibahas, karena tidak ada node dengan label dan properti yang ditentukan, itu membuatnya, seperti yang ditunjukkan pada tangkapan layar berikut.
OnCreate dan OnMatch
Setiap kali, kami menjalankan kueri gabungan, sebuah node dicocokkan atau dibuat. Menggunakan on create dan on match, Anda dapat menyetel properti untuk menunjukkan apakah node dibuat atau cocok.
Sintaksis
Berikut ini adalah sintaks OnCreate dan OnMatch klausul.
MERGE (node:label {properties . . . . . . . . . . .})
ON CREATE SET property.isCreated ="true"
ON MATCH SET property.isFound ="true"
Contoh
Berikut ini adalah contoh Permintaan Cypher yang mendemonstrasikan penggunaan OnCreate dan OnMatchklausul di Neo4j. Jika node yang ditentukan sudah ada di database, node tersebut akan dicocokkan dan properti dengan key-value pair isFound = "true" akan dibuat di node tersebut.
Jika node yang ditentukan tidak ada di database, node akan dibuat, dan di dalamnya properti dengan key-value pair isCreated = "true" akan dibuat.
MERGE (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
ON CREATE SET Jadeja.isCreated = "true"
ON MATCH SET Jadeja.isFound = "true"
RETURN Jadeja
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Seperti yang telah dibahas, karena tidak ada node dengan detail yang ditentukan, Neo4j membuatnya bersama dengan propertinyaisFound seperti yang ditunjukkan pada tangkapan layar berikut.
Gabungkan Hubungan
Sama seperti node, Anda juga dapat menggabungkan hubungan menggunakan klausa MERGE.
Contoh
Berikut adalah contoh Permintaan Cypher yang menggabungkan hubungan menggunakan klausa MATCH di Neo4j. Kueri ini mencoba menggabungkan hubungan bernamaWINNERS_OF antara node “ind” (label: Country & name: India) dan ICC13 (label: Tournament & name: ICC Champions Trophy 2013).
Karena relasi seperti itu tidak ada, Neo4j membuatnya.
MATCH (a:Country), (b:Tournament)
WHERE a.name = "India" AND b.name = "ICC Champions Trophy 2013"
MERGE (a)-[r:WINNERS_OF]->(b)
RETURN a, b
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Karena relasi yang ditentukan tidak ada dalam database, Neo4j membuatnya seperti yang ditunjukkan pada tangkapan layar berikut.
Dengan cara yang sama, Anda juga bisa menggabungkan beberapa hubungan dan hubungan tidak terarah.
Menggunakan klausa Set, Anda dapat menambahkan properti baru ke Node atau Relasi yang sudah ada, dan juga menambahkan atau memperbarui nilai Properti yang sudah ada.
Dalam bab ini, kita akan membahas bagaimana -
- Tetapkan properti
- Hapus properti
- Tetapkan beberapa properti
- Tetapkan label pada node
- Tetapkan beberapa label pada satu node
Mengatur Properti
Menggunakan klausa SET, Anda dapat membuat properti baru di sebuah node.
Sintaksis
Berikut ini adalah sintaks untuk menyetel properti.
MATCH (node:label{properties . . . . . . . . . . . . . . })
SET node.property = value
RETURN node
Contoh
Sebelum melanjutkan dengan contoh, pertama buat node bernama Dhawan seperti gambar di bawah ini.
CREATE (Dhawan:player{name: "shikar Dhawan", YOB: 1985, POB: "Delhi"})
Berikut adalah contoh Permintaan Cypher untuk membuat properti bernama "skor tertinggi" dengan nilai "187" .
MATCH (Dhawan:player{name: "shikar Dhawan", YOB: 1985, POB: "Delhi"})
SET Dhawan.highestscore = 187
RETURN Dhawan
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada gambar cuplikan berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa properti dengan key-value pair, nilai tertinggi / 187 dibuat di node bernama "Dhawan".
Menghapus Properti
Anda dapat menghapus properti yang sudah ada dengan melewatkan NULL sebagai nilai untuk itu.
Sintaksis
Berikut ini adalah sintaks menghapus properti dari node menggunakan klausa SET.
MATCH (node:label {properties})
SET node.property = NULL
RETURN node
Contoh
Sebelum melanjutkan dengan contoh, pertama buat simpul “jadeja” seperti yang ditunjukkan di bawah ini.
Create (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
Berikut ini adalah contoh Permintaan Cypher yang menghapus properti bernama POB dari node ini menggunakan klausa SET seperti yang ditunjukkan di bawah ini.
MATCH (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
SET Jadeja.POB = NULL
RETURN Jadeja
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa variabel bernamaPOB telah dihapus.
Mengatur Beberapa Properti
Dengan cara yang sama, Anda dapat membuat beberapa properti dalam satu node menggunakan klausa Set. Untuk melakukannya, Anda perlu menentukan pasangan nilai kunci ini dengan koma.
Sintaksis
Berikut adalah sintaks untuk membuat beberapa properti dalam satu node menggunakan klausa SET.
MATCH (node:label {properties})
SET node.property1 = value, node.property2 = value
RETURN node
Contoh
Berikut ini adalah contoh Permintaan Cypher yang membuat beberapa properti dalam sebuah node menggunakan klausa SET di Neo4j.
MATCH (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988})
SET Jadeja.POB: "NavagamGhed", Jadeja.HS = "90"
RETURN Jadeja
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa properti bernama POB dan HS telah dibuat.
Menetapkan Label pada Node
Anda dapat mengatur label ke node yang ada menggunakan klausa SET.
Sintaksis
Berikut ini adalah sintaks untuk menetapkan label ke node yang sudah ada.
MATCH (n {properties . . . . . . . })
SET n :label
RETURN n
Contoh
Sebelum melanjutkan dengan contoh, pertama buat node "Anderson" seperti yang ditunjukkan di bawah ini.
CREATE (Anderson {name: "James Anderson", YOB: 1982, POB: "Burnely"})
Berikut ini adalah contoh Query Cypher untuk mengatur label pada sebuah node menggunakan klausa SET. Kueri ini menambahkan label "pemain" ke node Anderson dan mengembalikannya.
MATCH (Anderson {name: "James Anderson", YOB: 1982, POB: "Burnely"})
SET Anderson: player
RETURN Anderson
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa label bernama "pemain" ditambahkan ke node.
Mengatur Beberapa Label pada Node
Anda dapat mengatur beberapa label ke node yang ada menggunakan klausa SET. Di sini Anda perlu menentukan label dengan memisahkannya dengan titik dua ":".
Sintaksis
Berikut adalah sintaks untuk mengatur beberapa label ke node yang ada menggunakan klausa SET.
MATCH (n {properties . . . . . . . })
SET n :label1:label2
RETURN n
Contoh
Sebelum melanjutkan dengan contoh, pertama buat node bernama "Ishant" seperti yang ditunjukkan di bawah ini.
CREATE (Ishant {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
Berikut adalah contoh Permintaan Cypher yang digunakan untuk membuat beberapa label pada sebuah node menggunakan klausa SET.
MATCH (Ishant {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
SET Ishant: player:person
RETURN Ishant
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa dua label - orang dan pemain - ditambahkan ke simpul bernamaIshant.
Anda dapat menghapus node dan hubungan dari database menggunakan klausa DELETE.
Menghapus Semua Node dan Relasi
Berikut ini adalah kueri untuk menghapus semua node dan relasi dalam database menggunakan klausa DELETE.
Pertanyaan
MATCH (n) DETACH DELETE n
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Ini akan menghapus semua node dan hubungan dari database neo4j Anda dan membuatnya kosong.
Menghapus Node Tertentu
Untuk menghapus node tertentu, Anda perlu menentukan detail node di tempat "n" dalam kueri di atas.
Sintaksis
Berikut ini adalah sintaks untuk menghapus node tertentu dari Neo4j menggunakan klausa DELETE.
MATCH (node:label {properties . . . . . . . . . . })
DETACH DELETE node
Contoh
Sebelum melanjutkan dengan contoh, buat node "Ishant" di database Neo4j seperti yang ditunjukkan di bawah ini.
CREATE (Ishant:player {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
Berikut ini adalah contoh Permintaan Cypher yang menghapus node yang dibuat di atas menggunakan klausa DELETE.
MATCH (Ishant:player {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
DETACH DELETE Ishant
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa node yang ditentukan dihapus.
Klausa REMOVE digunakan untuk menghapus properti dan label dari elemen grafik (Node atau Hubungan).
Perbedaan utama antara perintah Neo4j CQL DELETE dan REMOVE adalah -
- Operasi DELETE digunakan untuk menghapus node dan hubungan terkait.
- Operasi REMOVE digunakan untuk menghapus label dan properti.
Menghapus Properti
Anda dapat menghapus properti node menggunakan MATCH bersama dengan klausa REMOVE.
Sintaksis
Berikut adalah sintaks untuk menghapus properti node menggunakan klausa REMOVE.
MATCH (node:label{properties . . . . . . . })
REMOVE node.property
RETURN node
Contoh
Sebelum melanjutkan dengan contoh, buat node bernama Dhoni seperti gambar dibawah.
CREATE (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
Berikut ini adalah contoh Query Cypher untuk menghapus node yang dibuat di atas menggunakan klausa REMOVE.
MATCH (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
REMOVE Dhoni.POB
RETURN Dhoni
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini, Anda dapat mengamati bahwa node bernama POB telah dihapus.
Menghapus Label Dari Node
Mirip dengan properti, Anda juga dapat menghapus label dari node yang ada menggunakan klausa hapus.
Sintaksis
Berikut ini adalah sintaks untuk menghapus label dari sebuah node.
MATCH (node:label {properties . . . . . . . . . . . })
REMOVE node:label
RETURN node
Contoh
Berikut adalah contoh Query Cypher untuk menghapus label dari node yang ada menggunakan klausa remove.
MATCH (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
REMOVE Dhoni:player
RETURN Dhoni
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini, Anda dapat mengamati bahwa label telah dihapus dari node.
Menghapus Banyak Label
Anda juga dapat menghapus beberapa label dari node yang ada.
Sintaksis
Berikut adalah sintaks untuk menghapus beberapa label dari sebuah node.
MATCH (node:label1:label2 {properties . . . . . . . . })
REMOVE node:label1:label2
RETURN node
Contoh
Sebelum melanjutkan dengan contoh, buat node Ishant seperti yang ditunjukkan di bawah ini.
CREATE (Ishant:player:person {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
Berikut ini adalah contoh Permintaan Cypher untuk menghapus beberapa label dari sebuah node.
MATCH (Ishant:player:person {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
REMOVE Ishant:player:person
RETURN Ishant
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini, Anda dapat mengamati bahwa label yang ditentukan telah dihapus dari node.
Itu FOREACH klausa digunakan untuk memperbarui data dalam daftar apakah komponen jalur, atau hasil agregasi.
Sintaksis
Berikut ini adalah sintaks dari klausa FOREACH.
MATCH p = (start node)-[*]->(end node)
WHERE start.node = "node_name" AND end.node = "node_name"
FOREACH (n IN nodes(p)| SET n.marked = TRUE)
Contoh
Sebelum melanjutkan dengan contoh, buat jalur p di database Neo4j seperti yang ditunjukkan di bawah ini.
CREATE p = (Dhawan {name:"Shikar Dhawan"})-[:TOPSCORRER_OF]->(Ind{name:
"India"})-[:WINNER_OF]->(CT2013{name: "Champions Trophy 2013"})
RETURN p
Berikut ini adalah contoh Permintaan Cypher yang menambahkan properti ke semua node di sepanjang jalur menggunakan klausa FOREACH.
MATCH p = (Dhawan)-[*]->(CT2013)
WHERE Dhawan.name = "Shikar Dhawan" AND CT2013.name = "Champions Trophy 2013"
FOREACH (n IN nodes(p)| SET n.marked = TRUE)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Verifikasi
Untuk memverifikasi pembuatan node, ketik dan jalankan kueri berikut di prompt dollar.
MATCH (n) RETURN n
Kueri ini mengembalikan semua node dalam database (kita akan membahas kueri ini secara mendetail di bab-bab selanjutnya).
Saat menjalankan, kueri ini menunjukkan simpul yang dibuat seperti yang ditunjukkan pada tangkapan layar berikut.
Dalam bab ini, kita akan belajar tentang Klausa Pencocokan dan semua fungsi yang dapat dilakukan menggunakan klausa ini.
Dapatkan Semua Node Menggunakan Match
Menggunakan klausa MATCH dari Neo4j Anda dapat mengambil semua node di database Neo4j.
Contoh
Sebelum melanjutkan dengan contoh, buat 3 node dan 2 hubungan seperti yang ditunjukkan di bawah ini.
CREATE (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
CREATE (Ind:Country {name: "India", result: "Winners"})
CREATE (CT2013:Tornament {name: "ICC Champions Trophy 2013"})
CREATE (Ind)-[r1:WINNERS_OF {NRR:0.938 ,pts:6}]->(CT2013)
CREATE(Dhoni)-[r2:CAPTAIN_OF]->(Ind)
CREATE (Dhawan:player{name: "shikar Dhawan", YOB: 1995, POB: "Delhi"})
CREATE (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
CREATE (Dhawan)-[:TOP_SCORER_OF {Runs:363}]->(Ind)
CREATE (Jadeja)-[:HIGHEST_WICKET_TAKER_OF {Wickets:12}]->(Ind)
Berikut ini adalah kueri yang mengembalikan semua node dalam database Neo4j.
MATCH (n) RETURN n
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Mendapatkan Semua Node di Bawah Label Tertentu
Menggunakan klausa pertandingan, Anda bisa mendapatkan semua node di bawah label tertentu.
Sintaksis
Berikut adalah sintaks untuk mendapatkan semua node di bawah label tertentu.
MATCH (node:label)
RETURN node
Contoh
Berikut ini adalah contoh Permintaan Cypher, yang mengembalikan semua node dalam database di bawah label player.
MATCH (n:player)
RETURN n
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Cocokkan dengan Hubungan
Anda dapat mengambil node berdasarkan hubungan menggunakan klausa MATCH.
Sintaksis
Berikut ini adalah sintaks pengambilan node berdasarkan hubungan menggunakan klausa MATCH.
MATCH (node:label)<-[: Relationship]-(n)
RETURN n
Contoh
Berikut ini adalah contoh Permintaan Cypher untuk mengambil node berdasarkan hubungan menggunakan klausa MATCH.
MATCH (Ind:Country {name: "India", result: "Winners"})<-[: TOP_SCORER_OF]-(n)
RETURN n.name
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Hapus Semua Node
Anda dapat menghapus semua node menggunakan klausa MATCH.
Pertanyaan
Berikut ini adalah permintaan untuk menghapus semua node di Neo4j.
MATCH (n) detach delete n
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Itu OPTIONAL MATCH klausa digunakan untuk mencari pola yang dijelaskan di dalamnya, saat menggunakan null untuk bagian pola yang hilang.
OPSIONAL MATCH mirip dengan klausa pencocokan, satu-satunya perbedaan adalah ia mengembalikan null sebagai akibat dari bagian pola yang hilang.
Sintaksis
Berikut sintaks dari OPTIONAL MATCH with relationship.
MATCH (node:label {properties. . . . . . . . . . . . . .})
OPTIONAL MATCH (node)-->(x)
RETURN x
Contoh
Berikut ini adalah contoh Permintaan Cypher yang mencoba untuk mengambil relasi dari node ICCT2013. Karena tidak ada node seperti itu, ia mengembalikan null.
MATCH (a:Tornament {name: "ICC Champions Trophy 2013"})
OPTIONAL MATCH (a)-->(x)
RETURN x
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa karena tidak ada kecocokan untuk pola yang diperlukan, Neo4j mengembalikan null.
Seperti SQL, Neo4j CQL telah menyediakan klausa WHERE dalam perintah CQL MATCH untuk memfilter hasil dari MATCH Query.
Sintaksis
Berikut adalah sintaks klausa WHERE.
MATCH (label)
WHERE label.country = "property"
RETURN label
Contoh
Sebelum melanjutkan dengan contoh, buat lima node di database seperti yang ditunjukkan di bawah ini.
CREATE(Dhawan:player{name:"shikar Dhawan", YOB: 1985, runs:363, country: "India"}
CREATE(Jonathan:player{name:"Jonathan Trott", YOB:1981, runs:229, country:"South Africa"}
CREATE(Sangakkara:player{name:"Kumar Sangakkara", YOB:1977, runs:222,
country:"Srilanka"})
CREATE(Rohit:player{name:"Rohit Sharma", YOB: 1987, runs:177, country:"India"})
CREATE(Virat:player{name:"Virat Kohli", YOB: 1988, runs:176, country:"India"})
CREATE(Ind:Country {name: "India", result: "Winners"})
Berikut ini adalah contoh Query Cypher yang mengembalikan semua pemain (node) yang dimiliki negara India menggunakan klausa WHERE.
MATCH (player)
WHERE player.country = "India"
RETURN player
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
WHERE Klausul dengan Berbagai Ketentuan
Anda juga dapat menggunakan klausa WHERE untuk memverifikasi beberapa kondisi.
Sintaksis
Berikut ini adalah sintaks untuk menggunakan klausa WHERE di Neo4j dengan beberapa kondisi.
MATCH (emp:Employee)
WHERE emp.name = 'Abc' AND emp.name = 'Xyz'
RETURN emp
Contoh
Berikut ini adalah contoh Permintaan Cypher yang memfilter node dalam database Neo4j menggunakan dua kondisi.
MATCH (player)
WHERE player.country = "India" AND player.runs >=175
RETURN player
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Menggunakan Hubungan dengan Klausa Dimana
Anda juga dapat menggunakan klausa Where untuk memfilter node menggunakan hubungan.
Contoh
Asumsikan kita memiliki grafik berikut di database.
Berikut ini adalah contoh Query Cypher untuk mengambil top skorer India menggunakan klausa WHERE seperti yang ditunjukkan di bawah ini.
MATCH (n)
WHERE (n)-[: TOP_SCORER_OF]->( {name: "India", result: "Winners"})
RETURN n
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa Neo4j mengembalikan node, yang memiliki hubungan TOP_SCORER_OF ke negara dengan node yang bernama India.
Asumsikan kita telah membuat grafik di database dengan detail sebagai berikut.
Menghitung
Itu count() fungsi digunakan untuk menghitung jumlah baris.
Sintaksis
Berikut adalah sintaks dari fungsi hitungan.
MATCH (n { name: 'A' })-->(x)
RETURN n, count(*)
Contoh
Berikut ini adalah contoh Query Cypher yang mendemonstrasikan penggunaan count() fungsi.
Match(n{name: "India", result: "Winners"})--(x)
RETURN n, count(*)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Hitungan Grup
Itu COUNT klausa juga digunakan untuk menghitung kelompok jenis hubungan.
Contoh
Berikut ini adalah contoh Permintaan Cypher yang menghitung dan mengembalikan jumlah node yang berpartisipasi dalam setiap relasi.
Match(n{name: "India", result: "Winners"})-[r]-(x)
RETURN type (r), count(*)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Klausa RETURN digunakan simpul kembali, hubungan, dan properti di Neo4j. Dalam bab ini, kita akan belajar bagaimana -
- Kembalikan node
- Kembalikan beberapa node
- Kembalikan hubungan
- Kembalikan properti
- Kembalikan semua elemen
- Kembalikan variabel dengan alias kolom
Mengembalikan Node
Anda dapat mengembalikan sebuah node menggunakan klausa RETURN.
Sintaksis
Berikut ini adalah sintaks untuk mengembalikan node menggunakan klausa RETURN.
Create (node:label {properties})
RETURN node
Contoh
Sebelum melanjutkan dengan contoh, buat 3 node dan 2 hubungan seperti yang ditunjukkan di bawah ini.
Create (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
CREATE (Ind:Country {name: "India", result: "Winners"})
CREATE (CT2013:Tornament {name: "ICC Champions Trophy 2013"})
CREATE (Ind)-[r1:WINNERS_OF {NRR:0.938 ,pts:6}]->(CT2013)
CREATE(Dhoni)-[r2:CAPTAIN_OF]->(Ind)
Berikut ini adalah contoh Permintaan Cypher yang membuat node bernama Dhoni dan mengembalikannya.
Create (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
RETURN Dhoni
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Mengembalikan Banyak Node
Anda juga dapat mengembalikan beberapa node menggunakan klausa pengembalian.
Sintaksis
Berikut ini adalah sintaks untuk mengembalikan banyak node menggunakan klausa return.
CREATE (Ind:Country {name: "India", result: "Winners"})
CREATE (CT2013:Tornament {name: "ICC Champions Trophy 2013"})
RETURN Ind, CT2013
Contoh
Berikut adalah contoh Query Cypher untuk mengembalikan beberapa node menggunakan klausa return.
CREATE (Ind:Country {name: "India", result: "Winners"})
CREATE (CT2013:Tornament {name: "ICC Champions Trophy 2013"})
RETURN Ind, CT2013
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut. Di sini Anda dapat mengamati bahwa Neo4j mengembalikan 2 node.
Kembali Hubungan
Anda juga bisa mengembalikan hubungan menggunakan klausa Return.
Sintaksis
Berikut ini adalah sintaks untuk mengembalikan hubungan menggunakan klausa RETURN.
CREATE (node1)-[Relationship:Relationship_type]->(node2)
RETURN Relationship
Contoh
Berikut ini adalah contoh Permintaan Cypher yang membuat dua hubungan dan mengembalikannya.
CREATE (Ind)-[r1:WINNERS_OF {NRR:0.938 ,pts:6}]->(CT2013)
CREATE(Dhoni)-[r2:CAPTAIN_OF]->(Ind)
RETURN r1, r2
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Mengembalikan Properti
Anda juga dapat mengembalikan properti menggunakan klausa RETURN.
Sintaksis
Berikut ini adalah sintaks untuk mengembalikan properti menggunakan klausa RETURN.
Match (node:label {properties . . . . . . . . . . })
Return node.property
Contoh
Berikut ini adalah contoh Permintaan Cypher untuk mengembalikan properti dari sebuah node.
Match (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
Return Dhoni.name, Dhoni.POB
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Mengembalikan Semua Elemen
Anda dapat mengembalikan semua elemen dalam database Neo4j menggunakan klausa RETURN.
Contoh
Berikut adalah contoh Query Cypher untuk mengembalikan semua elemen dalam database.
Match p = (n {name: "India", result: "Winners"})-[r]-(x)
RETURN *
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Mengembalikan Variabel Dengan Alias Kolom
Anda dapat mengembalikan kolom tertentu dengan alias menggunakan klausa RETURN di Neo4j.
Contoh
Berikut ini adalah contoh Permintaan Cypher yang mengembalikan kolom POB sebagai Tempat Lahir.
Match (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
Return Dhoni.POB as Place Of Birth
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Anda dapat menyusun data hasil secara berurutan menggunakan klausa ORDER BY.
Sintaksis
Berikut ini adalah sintaks klausa ORDER BY.
MATCH (n)
RETURN n.property1, n.property2 . . . . . . . .
ORDER BY n.property
Contoh
Sebelum melanjutkan dengan contoh, buat 5 node di database Neo4j seperti yang ditunjukkan di bawah ini.
CREATE(Dhawan:player{name:"shikar Dhawan", YOB: 1985, runs:363, country: "India"})
CREATE(Jonathan:player{name:"Jonathan Trott", YOB:1981, runs:229, country:"South Africa"})
CREATE(Sangakkara:player{name:"Kumar Sangakkara", YOB:1977, runs:222, country:"Srilanka"})
CREATE(Rohit:player{name:"Rohit Sharma", YOB: 1987, runs:177, country:"India"})
CREATE(Virat:player{name:"Virat Kohli", YOB: 1988, runs:176, country:"India"})
Berikut adalah contoh Permintaan Cypher yang mengembalikan node yang dibuat di atas dalam urutan putaran yang dicetak oleh pemain menggunakan klausa ORDERBY.
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Mengurutkan Node berdasarkan Beberapa Properti
Anda dapat mengatur node berdasarkan beberapa properti menggunakan ORDEYBY ayat.
Sintaksis
Berikut adalah sintaks untuk mengatur node dengan beberapa properti menggunakan klausa ORDERBY.
MATCH (n)
RETURN n
ORDER BY n.age, n.name
Contoh
Berikut adalah contoh Cypher Query yang mengatur node yang dibuat sebelumnya dalam bab ini berdasarkan properti - run dan country.
MATCH (n)
RETURN n.name, n.runs, n.country
ORDER BY n.runs, n.country
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Mengurutkan Node dengan Urutan Menurun
Anda dapat mengatur node dalam database dalam urutan menurun menggunakan ORDERBY ayat.
Sintaksis
Berikut sintaks untuk menyusun node dalam database.
MATCH (n)
RETURN n
ORDER BY n.name DESC
Contoh
Berikut adalah contoh Permintaan Cypher yang mengatur node dalam database dalam urutan menurun menggunakan klausa ORDERBY.
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Itu limit klausa digunakan untuk membatasi jumlah baris dalam output.
Sintaksis
Berikut ini adalah sintaks dari klausa LIMIT.
MATCH (n)
RETURN n
ORDER BY n.name
LIMIT 3
Contoh
Sebelum melanjutkan dengan contoh, buat 5 node di database Neo4j seperti yang ditunjukkan di bawah ini.
CREATE(Dhawan:player{name:"shikar Dhawan", YOB: 1985, runs:363, country: "India"})
CREATE(Jonathan:player{name:"Jonathan Trott", YOB:1981, runs:229, country:"South Africa"})
CREATE(Sangakkara:player{name:"Kumar Sangakkara", YOB:1977, runs:222, country:"Srilanka"})
CREATE(Rohit:player{name:"Rohit Sharma", YOB: 1987, runs:177, country:"India"})
CREATE(Virat:player{name:"Virat Kohli", YOB: 1988, runs:176, country:"India"})
Berikut adalah contoh Cypher Query yang mengembalikan node yang dibuat di atas dalam urutan menurun dan membatasi record dalam hasil menjadi 3.
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
LIMIT 3
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Batasi dengan ekspresi
Anda juga dapat menggunakan klausa LIMIT dengan ekspresi.
Contoh
Berikut ini adalah contoh Permintaan Cypher yang membatasi rekaman menggunakan ekspresi.
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
LIMIT toInt(3 * rand())+ 1
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Klausa SKIP digunakan untuk menentukan dari baris mana untuk memulai termasuk baris dalam output.
Contoh
Sebelum melanjutkan dengan contoh, buat 5 node seperti yang ditunjukkan di bawah ini.
CREATE(Dhawan:player{name:"shikar Dhawan", YOB: 1985, runs:363, country: "India"})
CREATE(Jonathan:player{name:"Jonathan Trott", YOB:1981, runs:229, country:"South Africa"})
CREATE(Sangakkara:player{name:"Kumar Sangakkara", YOB:1977, runs:222, country:"Srilanka"})
CREATE(Rohit:player{name:"Rohit Sharma", YOB: 1987, runs:177, country:"India"})
CREATE(Virat:player{name:"Virat Kohli", YOB: 1988, runs:176, country:"India"})
Berikut ini adalah contoh Permintaan Cypher yang mengembalikan semua node dalam database yang melewati 3 node pertama.
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
SKIP 3
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Lewati Menggunakan Ekspresi
Anda dapat melewati rekaman hasil menggunakan ekspresi.
Contoh
Berikut ini adalah contoh Permintaan Cypher yang menggunakan klausa SKIP dengan ekspresi.
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
SKIP toInt (2*rand())+ 1
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Anda dapat merangkai seni kueri bersama-sama menggunakan klausa WITH.
Sintaksis
Berikut ini adalah sintaks klausa WITH.
MATCH (n)
WITH n
ORDER BY n.property
RETURN collect(n.property)
Contoh
Berikut adalah contoh Query Cypher yang mendemonstrasikan penggunaan klausa WITH.
MATCH (n)
WITH n
ORDER BY n.name DESC LIMIT 3
RETURN collect(n.name)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Klausa pelepasan digunakan untuk melepas daftar menjadi urutan baris.
Contoh
Berikut ini adalah contoh Permintaan Cypher yang membuka daftar.
UNWIND [a, b, c, d] AS x
RETURN x
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Seperti SQL, Neo4J CQL telah menyediakan sekumpulan fungsi String untuk digunakan dalam Kueri CQL untuk mendapatkan hasil yang diperlukan.
Di sini, kita akan membahas beberapa fungsi penting dan sering digunakan.
Daftar Fungsi String
Berikut adalah daftar fungsi String yang menonjol di Neo4j.
Sr Tidak | Deskripsi fungsi |
---|---|
1 | ATAS Ini digunakan untuk mengubah semua huruf menjadi huruf besar. |
2 | MENURUNKAN Ini digunakan untuk mengubah semua huruf menjadi huruf kecil. |
3 | SUBSTRING Ini digunakan untuk mendapatkan substring dari String tertentu. |
4 | Replace Ini digunakan untuk mengganti substring dengan substring tertentu dari sebuah String. |
Seperti SQL, Neo4j CQL telah menyediakan beberapa fungsi agregasi untuk digunakan dalam klausa RETURN. Ini mirip dengan klausa GROUP BY dalam SQL.
Kita dapat menggunakan perintah RETURN + Aggregation Functions in MATCH untuk mengerjakan sekelompok node dan mengembalikan beberapa nilai agregat.
Daftar Fungsi AGREGASI
Berikut adalah daftar fungsi agregasi di Neo4j.
Sr Tidak | Deskripsi fungsi |
---|---|
1 | MENGHITUNG Ini mengembalikan jumlah baris yang dikembalikan oleh perintah MATCH. |
2 | MAKS Ini mengembalikan nilai maksimum dari satu set baris yang dikembalikan oleh perintah MATCH. |
3 | MIN Ini mengembalikan nilai minimum dari satu set baris yang dikembalikan oleh perintah MATCH. |
4 | JUMLAH Ini mengembalikan nilai penjumlahan dari semua baris yang dikembalikan oleh perintah MATCH. |
5 | AVG Ini mengembalikan nilai rata-rata dari semua baris yang dikembalikan oleh perintah MATCH. |
Dalam aplikasi real-time, kita harus mencadangkan database aplikasi kita secara teratur, sehingga kita dapat memulihkan ke beberapa kondisi kerja pada titik kegagalan mana pun.
Aturan ini berlaku untuk database RDBMS dan NoSQL.
Di bagian ini, kita akan membahas tentang dua tugas DBA yang penting.
- Cara mencadangkan Database Neo4j.
- Cara memulihkan Database Neo4j ke cadangan tertentu.
Note- Langkah-langkah ini hanya berlaku untuk Sistem Operasi Windows. Kita harus menggunakan jenis perintah serupa untuk melakukan langkah yang sama di sistem operasi lain.
Pencadangan Database Neo4j
Step 1 - Klik "Neo4j Community" menggunakan jalur berikut -
Tombol "Start" Windows → "All Programs" → "Neo4j Community" → "Neo4j Community"
Secara default, itu memilih c:\Users\[username]\Documents\Neo4j\default.graphdb. Namun jika kita mau, kita dapat mengubah path ke direktori lain.
Step 2 - Di sini kami telah mengubah ke folder Database Neo4j kami.
C: \ Ne04j2.0db
Step 3 - Klik tombol "Mulai".
Setelah server dimulai, kami dapat mengamati file Database Neo4j kami dibuat di direktori yang ditentukan.
Sebelum melakukan backup database, hal pertama dan terpenting yang harus kita lakukan adalah mematikan server Database Neo4j.
Step 4 - Klik tombol "Stop" untuk mematikan server.
File Neo4j Database tersedia di C: \ Ne04j2.0db
Step 5 - Buka command prompt.
Step 6 - Buat folder "Neo4jDbBackup-01" di C: \ Neo4j (Ini mungkin lokasi mana pun di sistem file Anda).
mkdir C:\Neo4j\Neo4jDbBackup-01
Ini membuat folder baru "Neo4jDbBackup-01" di lokasi sistem file yang ditentukan "C: \ Neo4j \"
Step 7 - Ketik perintah berikut dan tekan tombol Enter.
copy C:\Ne04j2.0db C:\Neo4j\Neo4jDbBackup-01
Ini berarti file kami disalin ke folder tujuan yang diperlukan. Akses folder itu dan amati bahwa folder tersebut memiliki file database kita.
Step 8 - Gunakan alat kompresi / dekompresi Windows apa pun seperti WinZip, 7 Zip, atau WinRAR untuk membuat zip folder Database kami.
Step 9- Sekarang file Neo4jDbBackup-01.zip kami dibuat. Jika Anda memiliki kendala memori dalam sistem file Anda, hapus folder "Neo4jDbBackup-01" di "C: \ Neo4j \"
Neo4j Database Restore
Step 1- Matikan server database. Silakan lihat langkah-langkah sebelumnya untuk mematikan server.
Step 2 - Kosongkan folder database saat ini.
Step 3 - Gunakan alat kompresi / dekompresi Windows apa pun seperti WinZip, 7 Zip, atau WinRar untuk mengekstrak folder cadangan kami.
Step 4 - Buka command prompt dan jalankan perintah berikut.
Copy C:\Neo4j\Neo4jDbBackup-01 C:\Ne04j2.0db
Sekarang kita dapat mengamati bahwa folder database kita berisi file backup yang berfungsi
Step 5 - Mulai server dengan mengklik tombol "Mulai".
Step 6 - Jalankan beberapa perintah MATCH + RETURN untuk memverifikasi apakah kita telah memulihkan database kita dengan benar.
Neo4j SQL mendukung Indeks pada node atau properti hubungan untuk meningkatkan kinerja aplikasi. Kita dapat membuat indeks pada properti untuk semua node, yang memiliki nama label yang sama.
Kita dapat menggunakan kolom yang diindeks ini pada operator MATCH atau WHERE atau IN untuk meningkatkan eksekusi perintah CQL.
Dalam bab ini, kita akan membahas bagaimana -
- Buat Indeks
- Hapus Indeks
Membuat Indeks
Neo4j CQL menyediakan perintah "BUAT INDEKS" untuk membuat indeks pada properti Node atau Hubungan.
Sintaksis
Berikut ini adalah sintaks untuk membuat indeks di Neo4j.
CREATE INDEX ON:label (node)
Contoh
Sebelum melanjutkan dengan contoh, buat node Dhawan seperti gambar di bawah ini.
CREATE (Dhawan:player{name: "shikar Dhawan", YOB: 1995, POB: "Delhi"})
Berikut ini adalah sample Cypher Query untuk membuat index pada node Dhawan di Neo4j.
CREATE INDEX ON:player(Dhawan)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti gambar dibawah.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Menghapus Indeks
Neo4j CQL menyediakan perintah "DROP INDEX" untuk menghapus indeks yang ada dari Node atau Relasi propertinya.
Sintaksis
Berikut ini adalah sintaks untuk membuat indeks di Neo4j.
DROP INDEX ON:label(node)
Contoh
Berikut ini adalah contoh Query Cypher untuk membuat indeks pada node bernama “Dhawan” di Neo4j.
DROP INDEX ON:player(Dhawan)
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Dalam database Neo4j, perintah CQL CREATE selalu membuat node atau relasi baru yang berarti meskipun Anda menggunakan nilai yang sama, itu menyisipkan baris baru. Sesuai persyaratan aplikasi kami untuk beberapa node atau hubungan, kami harus menghindari duplikasi ini. Untuk ini, kita harus menggunakan beberapa batasan database untuk membuat aturan pada satu atau lebih properti dari node atau hubungan.
Seperti SQL, database Neo4j juga mendukung batasan UNIK pada node atau properti hubungan. Batasan UNIQUE digunakan untuk menghindari rekaman duplikat dan untuk menegakkan aturan integritas data.
Buat Batasan UNIK
Neo4j CQL menyediakan perintah "CREATE CONSTRAINT" untuk membuat batasan unik pada node atau properti hubungan.
Sintaksis
Berikut ini adalah sintaks untuk membuat batasan UNIK di Neo4j.
MATCH (root {name: "Dhawan"})
CREATE UNIQUE (root)-[:LOVES]-(someone)
RETURN someone
Contoh
Sebelum melanjutkan dengan contoh, buat 4 node seperti yang ditunjukkan di bawah ini.
CREATE(Dhawan:player{id:001, name: "shikar Dhawan", YOB: 1995, POB: "Delhi"})
CREATE(Jonathan:player {id:002, name: "Jonathan Trott", YOB: 1981, POB: "CapeTown"})
CREATE(Sangakkara:player {id:003, name: "Kumar Sangakkara", YOB: 1977, POB: "Matale"})
CREATE(Rohit:player {id:004, name: "Rohit Sharma", YOB: 1987, POB: "Nagpur"})
CREATE(Virat:player {id:005, name: "Virat Kohli", YOB: 1988, POB: "Delhi"})
Berikut ini adalah contoh Query Cypher untuk membuat batasan UNIK pada id properti menggunakan Neo4j.
CREATE CONSTRAINT ON (n:player) ASSERT n.id IS UNIQUE
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.
Verifikasi
Sekarang, coba tambahkan node lain dengan nilai id yang berlebihan. Di sini, kami mencoba membuat node dengan id002.
CREATE (Jadeja:player {id:002, name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
Jika Anda menjalankan kueri ini, Anda akan mendapatkan pesan kesalahan seperti yang ditunjukkan pada tangkapan layar berikut.
Kita telah membahas pembuatan operasi kendala UNIK dengan contoh di bab sebelumnya. Dalam bab ini, kita akan membahas menjatuhkan operasi kendala UNIK dengan contoh.
Neo4j CQL menyediakan perintah "DROP CONSTRAINT" untuk menghapus kendala unik yang ada dari node atau properti hubungan.
Sintaksis
Berikut ini adalah sintaks untuk menjatuhkan kendala UNIK di Neo4j.
DROP CONSTRAINT ON (node:label)
ASSERT node.id IS UNIQUE
Contoh
Berikut ini adalah contoh Permintaan Cypher untuk menghapus batasan UNIK pada properti id.
DROP CONSTRAINT ON (n:player)
ASSERT n.id IS UNIQUE
Untuk menjalankan kueri di atas, lakukan langkah-langkah berikut -
Step 1- Buka Aplikasi desktop Neo4j dan mulai Server Neo4j. Buka aplikasi browser bawaan Neo4j menggunakan URLhttp://localhost:7474/ seperti yang ditunjukkan pada tangkapan layar berikut.
Step 2 - Salin dan tempel kueri yang diinginkan di prompt dolar dan tekan tombol putar (untuk menjalankan kueri) yang disorot di tangkapan layar berikut.
Hasil
Saat menjalankan, Anda akan mendapatkan hasil sebagai berikut.