我正在使用Spring和Neo4j数据库进行这个项目。我将我的neo4j数据库配置为rest Neo4j。这是配置:
<neo4j:config graphDatabaseService="graphDatabaseService" />
<bean id="graphDatabaseService" class="org.springframework.data.neo4j.rest.SpringRestGraphDatabase">
<constructor-arg index="0" value="http://localhost:7474/db/data" />
</bean>一开始,我在域对象(@NodeEntity、@RelatedTo等)上使用符号。和存储库来保存节点和关系。我的域对象是用户(id,name)、Item(id、name、description、list of terms)、Term(content,count)。因此,没有那么多属性存在,但即便如此,通过存储库保存对象,例如,定义了id和名称的用户持续了25秒的。
我读到这种与neo4j数据库的通信还没有得到很好的优化,所以我使用Neo4jTemplate打开了。
这是保存用户的示例(用户中的约束为String ("id“、"name”、" user "):
public Node saveUser(User user) {
Node node = template.createNode();
node.setProperty(User.ID, user.getId());
node.setProperty(User.NAME, user.getName());
node.setProperty("_type", User.LABEL);
template.index(INDEX_ID, node, User.ID, user.getId());
return node;
}这是一个保存项目的例子,它与它的条款有关系。因此,每个术语都是连接到项的节点:
public Node saveItem(Item item) {
Node node = template.createNode();
node.setProperty(Item.ID, item.getId());
node.setProperty(Item.NAME, item.getName());
node.setProperty(Item.DESCRIPTION, item.getDescription());
node.setProperty("_type", Item.LABEL);
template.index(INDEX_ID, node, Item.ID, item.getId());
for(String termContent : item.getTerms()) {
Node term = termRepository.getNodeByContent(termContent);
if(term == null) {
term = termRepository.saveTerm(new Term(termContent));
} else {
termRepository.addCountToTerm(term);
}
int frequency = 1;
Relationship contains = node.createRelationshipTo(term, RelationshipTypes.CONTAINS);
contains.setProperty(Term.FREQUENCY, frequency);
}
return node;
}对象termRepository (它不是扩展GraphRespository<Term>)的方法类似于保存用户的方法。获取术语的过程如下所示:
public Node getNodeByContent(String content) {
if(!template.getGraphDatabaseService().index().existsForNodes(INDEX_ID))
return null;
return template.lookup(INDEX_ID, Term.CONTENT, content).to(Node.class).singleOrNull();
}最后,,我的问题是什么,。即使是现在,仍然慢于,插入用户(只有参数id和名称)并索引所需的3秒,插入连接到术语的项目需要30秒(4项--根据实际情况下的60-70项,这是非常小的值)。
拜托,你能给我一些提示或者其他能帮我解决这类问题的方法吗?提前谢谢。
发布于 2013-06-20 10:52:16
这是真正的限制,您的服务器在哪里运行?似乎与网络设置有关。
我的意思是,SDN对休息不是快,但也没有那么慢。
你也能分享你的课吗?
您不应该通过连线对单个属性进行更新。使用cypher语句一次创建所有属性。
还有neo4jTemplate.createNode(属性映射),它将其作为一个操作来执行。
https://stackoverflow.com/questions/17159221
复制相似问题