Rumah >pembangunan bahagian belakang >Golang >Cypher menemui (berbilang) nod 'paling rendah'.
Kes:
Nod Saya Categories
Seperti yang ditunjukkan di bawah, saya mencipta perhubungan dari kategori kepada ibu bapa.
CREATE(p1:Categorie { id: 2, parent_id: 1, name: "Kids", is_active: true , position: 1, level: 1, }) CREATE(c1:Categorie { id: 5, parent_id: 2, name: "Toys", is_active: true , position: 1, level: 2, }) //New root category CREATE(p2:Categorie { id: 9, parent_id: 1, name: "Holiday", is_active: true , position: 1, level: 1, }) CREATE(c2:Categorie { id: 12, parent_id: 9, name: "Water", is_active: true , position: 1, level: 2, }) CREATE(c1)-[:CHILD_OF]->(p1) CREATE(c2)-[:CHILD_OF]->(p2)
Kemudian produk saya mempunyai susunan categorie_ids
seperti ini:
<code>{ "sku": "abc", "name": "Electric boot", "categorie_ids": [ 1, 5, 9, 12 ] } </code>
API akan mengembalikan semua id di mana produk terletak "dalam". Semua hubungan sangat mengelirukan saya. Contoh ini adalah minimum, tetapi sebenarnya mungkin terdapat sehingga 20 perhubungan bagi setiap produk.
Soalan/Masalah:
Saya ingin mencipta hubungan dengan nod terendah dalam kategori. Dalam kes ini, produk mempunyai dua kategori utama dan oleh itu dua kategori bawah. Jadi saya ingin mencipta hubungan dengan id 12 dan 5.
Saya tidak dapat memahami carian kata laluan. Bolehkah seseorang menjelaskan perkara ini?
Anda pada asasnya melihat pertanyaan berikut:
Menurut model anda, anda sedang mempertimbangkan untuk menambah predikat yang tidak ada pada nod kategori INCOMING
类型的关系 CHILD_OF
WITH [1,5,9,12] AS categoryIds MATCH (n:Categorie) WHERE n.id IN categoryIds AND NOT ()-[:CHILD_OF]->(n) RETURN n.id
Atas ialah kandungan terperinci Cypher menemui (berbilang) nod 'paling rendah'.. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!