java高效遍历匹配,使用cypher或遍历api仅匹配路径极端的单个节点
假設(shè)我在圖表中有以下路徑:
(:Type1)()-[:RelType2]->(:Type2)-[:RelType1]->(:Type1)
給定 (:Type1) 左側(cè)的 (:Type1) 節(jié)點(diǎn),我能夠在路徑上方 MATCH 并在右側(cè)獲得相應(yīng)的 (:Type1) 節(jié)點(diǎn)(注意路徑是對(duì)稱的,其中心是節(jié)點(diǎn) (centernode) ) . 在我的用例中,我們獲得 的 (:Type1) 節(jié)點(diǎn),在另一側(cè)獲取相應(yīng)的 (:Type1) 節(jié)點(diǎn),然后進(jìn)一步處理 .
但是,我可能會(huì)得到 (:Type1) 的兩個(gè)節(jié)點(diǎn)的 . 在這種情況下,將從相應(yīng)的節(jié)點(diǎn)開始單獨(dú)的查詢,并將評(píng)估到另一側(cè)的 (:Type1) 節(jié)點(diǎn),因此將在兩個(gè)節(jié)點(diǎn)上繼續(xù)執(zhí)行 .
Q1. 如何避免處理兩個(gè)節(jié)點(diǎn) . 也就是說,如果給出位于同一路徑極端的兩個(gè) (:Type1) 節(jié)點(diǎn),我怎樣才能確保只執(zhí)行從另一側(cè)節(jié)點(diǎn)匹配的其中一個(gè)節(jié)點(diǎn)開始的一個(gè)查詢,以便只有其中一個(gè)節(jié)點(diǎn)進(jìn)一步處理并且其他節(jié)點(diǎn)被稱為保持在臨時(shí)緩沖區(qū)中以便隨后處理(如果第一節(jié)點(diǎn)的處理失敗) .
Added fact: 上面我有一條路徑,兩端有兩個(gè) (:Type1) 節(jié)點(diǎn) . 我可能有三個(gè)或更多路徑從 (centernode) 發(fā)出并在 (:Type1) 節(jié)點(diǎn)結(jié)束 . 因此,我希望首先處理這些 (:Type1) 節(jié)點(diǎn)中的一個(gè)節(jié)點(diǎn),并且只有在早期處理失敗時(shí)才會(huì)處理下一個(gè) (:Type1) 節(jié)點(diǎn) .
Q2. 這種情況甚至可以用純密碼進(jìn)行嗎?或者我必須最終使用Neo4J Traversal API?如果是,如何做到這一點(diǎn),因?yàn)槲冶仨毚_保在兩個(gè)不同的traveresals訪問的節(jié)點(diǎn)/關(guān)系的唯一性 .
Q3. 如何在Traversal API中添加路徑擴(kuò)展器以匹配 (:Type1)
at each traversal `next()`
if (node is of Type1)
follow
if (node is of Type2)
follow
(上面是偽代碼 . 我是Traversal API的新手 . 我已經(jīng)瀏覽了所有文檔和示例 . 所以我猜測(cè)擴(kuò)展器內(nèi)部我必須放置 if() 過濾器來檢查當(dāng)前節(jié)點(diǎn)類型并決定接下來擴(kuò)展哪種關(guān)系類型及其方向 . 以上偽代碼用于表示 . )
這是如何在Traversal API中編寫這樣的密碼嗎?還是有更好的方法嗎?
總結(jié)
以上是生活随笔為你收集整理的java高效遍历匹配,使用cypher或遍历api仅匹配路径极端的单个节点的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: matlab三维feather,matl
- 下一篇: 如何编译java,java如何编译运行?