日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java高效遍历匹配,使用cypher或遍历api仅匹配路径极端的单个节点

發布時間:2024/10/8 编程问答 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java高效遍历匹配,使用cypher或遍历api仅匹配路径极端的单个节点 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

假設我在圖表中有以下路徑:

(:Type1)()-[:RelType2]->(:Type2)-[:RelType1]->(:Type1)

給定 (:Type1) 左側的 (:Type1) 節點,我能夠在路徑上方 MATCH 并在右側獲得相應的 (:Type1) 節點(注意路徑是對稱的,其中心是節點 (centernode) ) . 在我的用例中,我們獲得 的 (:Type1) 節點,在另一側獲取相應的 (:Type1) 節點,然后進一步處理 .

但是,我可能會得到 (:Type1) 的兩個節點的 . 在這種情況下,將從相應的節點開始單獨的查詢,并將評估到另一側的 (:Type1) 節點,因此將在兩個節點上繼續執行 .

Q1. 如何避免處理兩個節點 . 也就是說,如果給出位于同一路徑極端的兩個 (:Type1) 節點,我怎樣才能確保只執行從另一側節點匹配的其中一個節點開始的一個查詢,以便只有其中一個節點進一步處理并且其他節點被稱為保持在臨時緩沖區中以便隨后處理(如果第一節點的處理失敗) .

Added fact: 上面我有一條路徑,兩端有兩個 (:Type1) 節點 . 我可能有三個或更多路徑從 (centernode) 發出并在 (:Type1) 節點結束 . 因此,我希望首先處理這些 (:Type1) 節點中的一個節點,并且只有在早期處理失敗時才會處理下一個 (:Type1) 節點 .

Q2. 這種情況甚至可以用純密碼進行嗎?或者我必須最終使用Neo4J Traversal API?如果是,如何做到這一點,因為我必須確保在兩個不同的traveresals訪問的節點/關系的唯一性 .

Q3. 如何在Traversal API中添加路徑擴展器以匹配 (:Type1)

at each traversal `next()`

if (node is of Type1)

follow

if (node is of Type2)

follow

(上面是偽代碼 . 我是Traversal API的新手 . 我已經瀏覽了所有文檔和示例 . 所以我猜測擴展器內部我必須放置 if() 過濾器來檢查當前節點類型并決定接下來擴展哪種關系類型及其方向 . 以上偽代碼用于表示 . )

這是如何在Traversal API中編寫這樣的密碼嗎?還是有更好的方法嗎?

總結

以上是生活随笔為你收集整理的java高效遍历匹配,使用cypher或遍历api仅匹配路径极端的单个节点的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。