使用Cloudant和AngularJS进行特定搜索

时间:2017-07-26 13:06:54

标签: php angularjs cloudant

我在我的Cloudant上有一个搜索索引,我使用AngularJS和PHP进行查询。

到目前为止,我没有得到足够具体的结果。

例如,在使用fair:'Fair 2017'的搜索中,我获得包含Fair的所有结果,包括Fair 2016等。

我尝试过不同的搜索类型(简单,标准,经典),并且所有搜索类型都会发生。

一个典型的对象:

doc:Object
  exhibitortype:"Project Space"
  fair:"Fair 2017"
  ...

这是我的AngularJS代码:

$scope.loadexhibitors = function(fair){
  $scope.searchindex = fair.doc.fairname;

  var $promisefairexh=$http({
    url: 'databaseconnect/getexhibitors.php', 
    method: "GET",
    params: {search: $scope.searchindex}
  });
...

PHP位如下所示:

<?php

    $search = $_GET["search"];
    $newsearch = str_replace(' ', '+', $search);

    $url = "https://user:pass.@user.cloudant.com/db/_design/fairs/_search/by_fair?q='$newsearch'&include_docs=true";
    $ch = curl_init();   // initialize curl handle
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
    $output = curl_exec($ch);

    $info = curl_getinfo($ch);
    curl_close($ch);
?>

我的Cloudant搜索功能:

function (doc) {
  index("default", doc.fair);
}

另一方面,在Cloudant用户界面上,当我测试搜索索引并在搜索输入上包含双引号时(例如:&#34; Fair 2016&#34;而不是Fair 2016),我得到了期望的结果。

任何提示?

1 个答案:

答案 0 :(得分:1)

尝试在搜索中使用双引号而不是单引号,例如:

$url = "https://user:pass.@user.cloudant.com/db/_design/fairs/_search/by_fair?q=\"$newsearch\"&include_docs=true";

注意对q param的更改:

q=\"$newsearch\"