使用 Amazon Neptune 作為 GraphDB,我正在嘗試更新某些頂點的屬性以包含值列表。本指南中的基本 gremlin 示例:// Add a list as a property valueg.V().has('code','AUS').property('places',out().values('code').fold()) 失敗了:{ "requestId": "XXX", "detailedMessage": "Unsupported property value type: java.util.ArrayList", "code": "UnsupportedOperationException"}我也嘗試添加list修飾符g.V().has('code','AUS').property(list, 'places',out().values('code').fold())失敗了:{ "requestId": "XXX", "detailedMessage": "list cardinality for vertex property is not supported", "code": "UnsupportedOperationException"}如果出于某種原因,python-gremlin 或 Amazon Neptune 風(fēng)格不支持?jǐn)?shù)組或列表作為屬性值,我可以接受將值連接成單個字符串的單個值。我嘗試使用各種選項:g.V().has('code','AUS').property('places',out().values('code').fold(0) {a,b -> a + b.length()})或者g.V().has('code','AUS').property('places',out().values('code')map {join(",",it.get().value('code'))})但沒有一個在工作。
1 回答

www說
TA貢獻1775條經(jīng)驗 獲得超8個贊
我認(rèn)為您必須在單獨的property步驟中插入每個值
像這樣:
g.V().has('code', 'AUS').as('airport').
out().values('code').as('code').select('airport').
property(set, 'places', select('code'))
編輯:
我在 AWS用戶指南中看到不支持列表基數(shù)。因此最接近的解決方案是使用set基數(shù)。
Neptune 支持集合基數(shù)和單一基數(shù)。如果未指定,則選擇設(shè)置基數(shù)。這意味著如果您設(shè)置一個屬性值,它會向該屬性添加一個新值,但前提是它尚未出現(xiàn)在值集中。這是 Set 的 Gremlin 枚舉值。不支持列表。有關(guān)屬性基數(shù)的更多信息,請參閱 Gremlin JavaDoc 中的頂點主題。
示例:https ://gremlify.com/9v
添加回答
舉報
0/150
提交
取消