0

Cloudant サーバーに次のようなドキュメントがあります。

 {
  "_id": "web",
  "_rev": "11-b1d0e315272a87c2549df4004d836049",
  "min_weight": 40,
  "max_weight": 65,
  "min_length": 1,
  "max_length": 2.2,
  "attributeCollection": {
    "attributeArray": [
      {
        "updateable": false,
        "lookup": "issuetype",
        "issueAttributeDefinitionId": 13,
        "attributeType": 1,
        "name": "web issue",
        "value": [
          "Improper Neutralization of Input During Web Page Generation"
        ]
      }
    ]
  },
}

ドキュメントの「名前」と「値」の検索インデックスを次のように作成しました。

function (doc) {
   if (doc.attributeCollection && doc.attributeCollection.attributeArray) {
      for (var i=0; i<doc.attributeCollection.attributeArray.length; i++) {
         if (doc.attributeCollection.attributeArray[i].name) {
            index("name", doc.attributeCollection.attributeArray[i].name, { store : true });
         }
            if (doc.attributeCollection.attributeArray[i].value) {
            for (var j=0; j<doc.attributeCollection.attributeArray[i].value.length; j++) {
               index("value", doc.attributeCollection.attributeArray[i].value[j], { store : true });
            }
         }
      }
   }
}

https://xxx.cloudant.com/issuedb/_design/searchJson/_search/newSearch?limite=10&include_docs=true&q=name:"web*"結果を取得するために、ブラウザーでクエリ ( ) を正常に実行しました。また、cloudant-client api で結果を取得したい。以下は私のコードです

CloudantClient client=new CloudantClient("xxx", "xxx", "xxx" );
System.out.println("Connection successful! "+client.getBaseUri());
Database db=client.database("issuedb", true);
System.out.println("Datase available - "+db.getDBUri());

List<issue> issues=db.search("searchJson/newSearch")
.limit(10).includeDocs(true)
.query("name=\"web*\"", issue.class);

for (int i = 0; i < issues.size(); i++) {
    issue iss=issues.get(i);
    System.out.println(iss.getId());
    System.out.println(iss.getName());
    System.out.println(iss.getValue());
}

しかし、ブラウザで検索クエリとして結果を取得することはできません (データとインデックスの接続もチェックされます。問題ありません)。このコードの間違いは何ですか。

4

1 に答える 1

3

Search indexes are queried using Lucene Query Parser Syntax. try using a colon instead of the equal sign:

List<issue> issues=db.search("searchJson/newSearch")
.limit(10).includeDocs(true)
.query("name:\"web*\"", issue.class);

More Info:
Cloudant Search
Lucene Query Parser Syntax

于 2016-04-14T12:21:43.133 に答える