Meteor db.find与json内的日期作为选择器无法正常工作

时间:2015-11-05 15:53:51

标签: javascript mongodb meteor

我通过互联网阅读了大量资源,并按照很多例子说明如何在特定日期范围内找到一个集合并且它没有用。我的代码如下: -

var fromAge = 18;
var toAge = 22;
Meteor.users.find({:profile.birthday":{$lt: new Date(new Date().setYear(new Date().getFullYear() - fromAge)), $gt: new Date(new Date().setYear(new Date().getFullYear() - toAge))}).fetch();

当我做一个简单的Meteor.users.find()时,上面的查询返回一个空集合.fetch()它确实返回了下面的一条记录: -

{"_id": 123452345, "profile.birthday": ISODATE("1975-10-22T00:00:00Z")}

进行调试,我还在javascript控制台和后端服务器mongo shell上编写了以下查询,并且它确实返回了空集合。

Javascript控制台

Meteor.users.find({"profile.birthday": {$lt: new Date()}})

服务器MongoDB Shell

db.users.find{"profile.birthday": {$lt: new Date()}})

我现在不知道。如果有人能够启发我会很棒。

- 更新 -

我尝试了以下查询,但确实没有返回任何内容

db.users.find({"profile.birthday":{$lt: new Date(new Date().setYear(new Date().getFullYear() - 18)).toISOString()}})

我在javascript控制台中输入了命令

new Date(new Date().setYear(new Date().getFullYear() - 18)).toISOString()

它确实告诉了我

"1997-11-06T16:35:28.844Z"

它是我的数据库,生日的记录应该是" 1975-10-22T00:00:00Z"因此它应该达到这个记录,但我所拥有的只是一个空集合。

有人告诉我使用ISODate(),我尝试了以下命令,它在MongoDB Shell中运行,而它在我的Meteor助手函数中产生了ISODate Undefined。

db.users.find({"profile.birthday":{$lt: ISODate("1977-11-06")})

已经通过其他一些资源(Inserting and Querying Date with MongoDB and Nodejs)阅读并了解到我应该使用Date而不是ISODate,其中ISODate是MongoDB的内部,而Meteor将有助于将日期转换为ISODate转换。然后我尝试对查询进行硬编码,它确实可以正常工作: -

db.users.find({"profile.birthday": {$lt: new Date("1977-11-06T00:00:00.000Z")}})

- UPDATE BEGIN (2015年11月16日) -

它运行正常,而我的问题是我试图在json中构建选择器然后将它放入find中,而这不起作用: -

selector={"profile.birthday": {$lt: new Date("1977-11-06T00:00:00:000Z"}};
db.users.find(selector);

以上查询根本没有返回任何内容。

- 更新结束(2015年11月16日) -

我这样做是因为我有一个年龄组的下拉,我正在尝试通过帮助器事件构建查询。我有一个下拉模板: - /client/ageRangeDropdown.html

<template name="AgeRangeDropdown">
  <div class="btn-group">
    Age Group
    <select id="ageRangeDropdownList" class="form-control">
      <option >Whatever</option>
      <option >18-22</option>
      <option >23-27</option>
      <option >28-32</option>
      <option >33-37</option>
      <option >38-42</option>
      <option >43-47</option>
      <option >48-52</option>
      <option >53-57</option>
    </select> 
  </div>
  {{#each currentCriterias}}
    <span class="label label-info">{{criteria}}</span>
  {{/each}}
  {{#each myUser}}
    {{profile.firstName}} ,  {{profile.lastName}}, {{profile.birthday}}
  {{/each}}
</template>

以下的帮手

/client/ageRangeDropdown.js

Template.ageRangeDropdown.events({
  'change ageRangeDropdownList': function(e) {
  for (var key in target) {
    if (!target.hasOwnProperty(key)) {
      if (key=='id') {
        id = target[key];
      }
    }  
  }
  var value = target.options[target.selectedIndex].value;
  if (value!='Whatever') {
    currentCriterias.push({id: "profile.birthday", criteriaValue: value});
  }
  var query = [];
  for (var i = 0; i < items.length; i++) {
    var itemObject = {};
    var fromAge = currentCriterias[i]['criteriaValue'].substr(0,2);
    var toAge = currentCriterias[i]['criteriaValue'].substr(3,2);
      itemObject['profile.birthday'] = {
        $gt: new Date(new Date().setYear(new Date().getFullYear() - fromAge)),
        $lt: new Date(new Date().setYear(new Date().getFullYear() - toAge))
      }
    query.push(itemObject);
  }
  var selector  = [];
  selector.push({$or: query});
  Template.instance().selector.set({$or: selector});

  return false;
})

Templage.ageRangeDropdown.created = function() {
  var instance = this;
  instance selector = new RactiveVar([]);

  instance.autorun(function() {
    var selector = instance.selector.get();
    if (typeof selector != 'undefined' && Object.keys(selector).length > 0) {
        var subscription = instance.subscribe('searchUser', selector);
    }
  });

  instance.myUser = function() {
    var selector = instance.selector.get();
    if (typeof selector != 'undefined' && Object.keys(selector).length > 0) {
      return Meteor.users.find(selector, {fields: {profile: 1}});
    }
  }
}

服务器/ serverpublish.js

Meteor.publish("searchUser", function(selector){
  if (!this.userId) {
      console.log("Cannot search User when you haven't logged in.");
      return null;
  } else {
      if (typeof selector != 'undefined' || Object.keys(selector).length > 0) {
        var user=Meteor.users.find(selector, {fields: {profile: 1}});
        return user;
      } else {
        console.log("won't publish all user profiile when no selector is given");
        return null;
      }
    }
});

逻辑就是这样,实际上我有很多下拉列表,每个下拉列表都构成查询的一部分,我使用实例反应变量设置查询,这样每当它发生变化时,meteor都会再次执行meteor.find。每个下拉列表工作正常,但这个生日是一个日期。任何人都知道出了什么问题?

2 个答案:

答案 0 :(得分:0)

<强>提示:

在mongodb shell中尝试以下查询格式。

db.users.find( 
    {"profile.birthday":{ 
        $gte: ISODate(fromAge),
        $lt: ISODate(toAge)
    }
})

fromAgetoAge应该是正确的格式。

答案 1 :(得分:0)

从另一个论坛我得到了答案。

有关详情,请参阅https://forums.meteor.com/t/meteor-db-find-with-date-inside-a-json-as-selector-not-working/12892/9

简而言之,我只是在查询中新建了一个Date对象

query[DBPrefix] = {
  $lte: new Date(fromDate),
  $gte: new Date(toDate)
}