将节点转换为对象

时间:2018-10-12 09:22:55

标签: java json neo4j neo4j-ogm jooby

假设我无权访问StatementResult,将Neo4j session执行的SessionFactory转换为适当的对象或至少是Json的正确方法是什么?

我正在这样做,看起来笨拙和冗长:

var session = require(Driver.class).session(); // v1 Driver, v1 Session
try (session) {
    Iterable<Record> iterable =
            () -> session.run(FIND_BY_TITLE_LIKE, Map.of("titleLike", ".*" + titleLike + ".*"));
    var list = StreamSupport
            .stream(iterable.spliterator(), false)
            .map(Record::asMap)
            .map(Map::values)
            .flatMap(Collection::stream) // nodes
            .map(node -> ((InternalNode) node).asMap())
            .collect(Collectors.toList());
    LOGGER.info("Processed list: {}", list);
    return list;
}

也许我应该为此使用其他DriverSession吗?

1 个答案:

答案 0 :(得分:0)

您可以使用Spring-Data-Neo4j(SDN)将查询结果映射到域实体。您只需要以下三个代码段。

存储库

@Repository
public interface NodeEntityNameDAO extends Neo4jRepository<NodeEntityName, Long> {
  @Query("MATCH (nodeA:LabelA)<-[:CONTAINS]-(nodeB:LabelB) RETURN nodeA.name AS nodeAName, nodeB.name AS nodeBName;")
  NodeAAndBResult[] getNodeAAndB();
}

结果对象

@QueryResult
public class NodeAAndBResult {
  private String nodeAName;
  private String nodeBName;

  // omitted default constructor as well getter and setter for clarity
}

业务逻辑

NodeAAndBResult[] nodeAAndBResults = nodeEntityNameDAO.getNodeAAndB();

附录

刚刚从GraphAware的@Luanne找到了一个wonderful article,就是同一主题。