2016-09-20 11 views
1

私はすべてのカメラを取り、「青写真」に関連付けられたカメラをフィルタリングするフィルタを作成する必要があります。これはMongoDBのカメラのプロパティ内にあります。タイプ"BluePrint"のないカメラを除外したい。ElasticSearch特定のカメラをフィルタリングするクエリ

修正する必要があるセクションは、getAllCamerasqueryセクションです。 elasticsearchにいくつかの研究の後

self.evaluateCameras = function() { 
    self.getAllCameras(function(err, cameras) { 
     if(err) { 
      console.log(err); 
     } 
     else { 
      // -- publish newly included cameras 
      cameras.forEach(function(camera) { 
       if(self.includedCameras[camera._id] == undefined) { 
        camera._source.entityId = camera._id; 
        camera._source.systemType = camera._type; 
        self.publish(camera._source, "create") 
        // -- to scale this need to do caching in Redis shared cache across processes 
        self.includedCameras[camera._id] = camera; 
       } 
      }); 
     } 

     // process any messages received while initializing stream 
     self.initComplete = true; 
     for(var j = 0; j < self.tempMessageCache.length; j++) { 
      var cacheMsg = self.tempMessageCache[j]; 
      self.evalPublish(cacheMsg); 
     } 
     self.tempMessageCache = []; 

    }); 
}; 

self.getAllCameras = function(callback) { 
    self.q = { 
     "from": 0, 
     "size": 10000, // -- todo: implement some kind of paging 
     "sort": [ 
      {'properties.name': 'asc'}, 
      {'properties.cameraId': 'asc'} 
     ], 
     "query": { 
      "filtered": { 
       "query": { 
        "match_all": {} 
       }, 
       "filter": { 
        "and": [ 
         { 
          "exists": {"field": "properties.geoRef"} 
         }, 
         { 
          "geo_shape": { 
           "properties.geoRef": { 
            "shape": { 
             "coordinates": properties.geoRef.coordinates, 
             "type": "point" 
            } 
           } 
          } 
         } 
        ] 
       } 
      } 
     } 
    }; 
    elasticClient.search({ 
     index: 'myproject-now', 
     type: 'system.camera', 
     body: self.q 
    }, function (err, response) { 
     if (err) 
      callback(err, null); 
     else { 
      callback(null, response.hits.hits); 
     } 
    }); 
}; 

答えて

0

これは私が思いついたのソリューションです:

self.getAllCameras = function(callback) { 
    self.q = { 
     "from": 0, 
     "size": 10000, // -- todo: implement some kind of paging 
     "sort": [ 
      {'properties.name': 'asc'}, 
      {'properties.cameraId': 'asc'} 
     ], 
     "query": { 
      "filtered": { 
       "query": { 
        "match_all": {} 
       }, 
       "filter": { 
        "and": [ 
         { 
          "exists": {"field": "properties.geoRef"} 
         }, 
         { 
          "not": { 
           "term": { 
            "properties.geoRef.type" : "floorplan" 
           } 
          } 
         } 
        ] 
       } 
      } 
     } 
    }; 
    elasticClient.search({ 
     index: 'myproject-now', 
     type: 'system.camera', 
     body: self.q 
    }, function (err, response) { 
     if (err) 
      callback(err, null); 
     else { 
      callback(null, response.hits.hits); 
     } 
    }); 
}; 
関連する問題