1

假设我无权访问,将StatementResultNeo4j执行转换为正确的对象或至少是 Json 的正确方法是什么?sessionSessionFactory

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

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为此?

4

1 回答 1

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 中找到了一篇精彩的文章,来自 GraphAware 的 @Luanne,主题相同。

于 2018-10-12T15:08:53.893 回答