假设我无权访问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;
}
也许我应该为此使用其他Driver
或Session
吗?
答案 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,就是同一主题。