暗号クエリに奇妙な問題があります。クエリは Neoclipse で正常に機能し、正しい結果を返します。しかし、Java 組み込みモードでは、結果は空です。問題がわかりません。Java埋め込みまたは同様のものにクエリ文字制限はありますか?
暗号クエリは次のとおりです。
START
typeNode6=node(6) ,
containerNode=node(9) ,
typeNode35=node(35) ,
typeNode15=node(15) ,
typeNode18=node(18) ,
typeNode33=node(33)
MATCH (node6)-[:TYPE]->(typeNode6) ,
(containerNode)-[:CONTAINS*]->(node6) ,
(node35)-[:TYPE]->(typeNode35) ,
(node6)-[:`http://www.test.test/types/s3/media#actors`]->(node35) ,
(node15)-[:TYPE]->(typeNode15) ,
(node35)-[:`http://www.test.test/types/s3/media#impersonatedBy`]->(node15) ,
(node18)-[:TYPE]->(typeNode18) ,
(node15)-[:`http://www.test.test/types/common#namedBy`]->(node18) ,
(node33)-[:TYPE]->(typeNode33) ,
(node6)-[:`http://www.test.test/types/s3/media#runtime`]->(node33)
WHERE
node6.`http://www.test.test/types/s3/media#releaseYear`! = 1988
AND node18.`http://www.test.test/types/common#firstName`! = 'Robert'
AND node18.`http://www.test.test/types/common#lastName`! = 'Davi'
AND node33.`http://www.test.test/types/common#intValue`! = 131 RETURN node6";
ここに私のJavaテストクラスがあります:
@Test
public void queryExecute() {
ExecutionResult result, result2;
ExecutionEngine engine;
String query = "START typeNode6=node(6) ,containerNode=node(9) ,typeNode35=node(35) ,typeNode15=node(15) ,typeNode18=node(18) MATCH (node6)-[:TYPE]->(typeNode6) ,(containerNode)-[:CONTAINS*]->(node6) ,(node35)-[:TYPE]->(typeNode35) , (node6)-[:`http://www.test.test/types/s3/media#actors`]->(node35) ,(node15)-[:TYPE]->(typeNode15) , (node35)-[:`http://www.test.test/types/s3/media#impersonatedBy`]->(node15) ,(node18)-[:TYPE]->(typeNode18) , (node15)-[:`http://www.test.test/types/common#namedBy`]->(node18) WHERE node18.`http://www.test.test/types/common#firstName`! = 'Robert' AND node18.`http://www.test.test/types/common#lastName`! = 'Davi' RETURN node6";
String query2 = "START typeNode6=node(6) ,containerNode=node(9) ,typeNode35=node(35) ,typeNode15=node(15) ,typeNode18=node(18) ,typeNode33=node(33) MATCH (node6)-[:TYPE]->(typeNode6) ,(containerNode)-[:CONTAINS*]->(node6) ,(node35)-[:TYPE]->(typeNode35) , (node6)-[:`http://www.test.test/types/s3/media#actors`]->(node35) ,(node15)-[:TYPE]->(typeNode15) , (node35)-[:`http://www.test.test/types/s3/media#impersonatedBy`]->(node15) ,(node18)-[:TYPE]->(typeNode18) , (node15)-[:`http://www.test.test/types/common#namedBy`]->(node18) ,(node33)-[:TYPE]->(typeNode33) , (node6)-[:`http://www.test.test/types/s3/media#runtime`]->(node33) WHERE node6.`http://www.test.test/types/s3/media#releaseYear`! = 1988 AND node18.`http://www.test.test/types/common#firstName`! = 'Robert' AND node18.`http://www.test.test/types/common#lastName`! = 'Davi' AND node33.`http://www.test.test/types/common#intValue`! = 131 RETURN node6";
engine = new ExecutionEngine(svrInstance.getNeoGraphdb());
result = engine.execute(query);
result2 = engine.execute(query2);
Assert.assertNotNull(result);
System.out.println("============== CYPHER QUERY TEST ==============");
System.out.println("uncomplicated: ");
System.out.println(result.toString());
System.out.println("complicated: ");
System.out.println(result2.toString());
System.out.println("============== CYPHER QUERY TEST ==============");
}
そして、これは Java コンソールからの出力です。
============== CYPHER QUERY TEST ==============
uncomplicated:
+---------------------------------------------------------------------------------------------------------------------------------------------------+
| node6 |
+---------------------------------------------------------------------------------------------------------------------------------------------------+
| Node[7]{http://www.test.test/types/common#id:"movie_1",http://www.test.test/types/s3/media#releaseYear:1988,type:"instance",instanceId:"movie_1"} |
+---------------------------------------------------------------------------------------------------------------------------------------------------+
1 row
138 ms
complicated:
+-------+
| node6 |
+-------+
+-------+
0 row
4 ms
============== CYPHER QUERY TEST ==============
両方のクエリ (Java の場合) は同じ結果を返す必要があります (少なくとも Neoclipse の場合)。違いは、「複雑なクエリ」がより多くの「WHERE」条件を取得したことです。
ちなみに、クエリは Java から動的に生成されますが、Neoclipse で動作するため、これは問題にはなりません。(そして、私は常に同じデータベースの場所を使用しました。)
助けてくれてありがとう!あいさつマックス