Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mongodb 关于字段名不区分大小写的Mongo查询_Mongodb_Case Insensitive - Fatal编程技术网

Mongodb 关于字段名不区分大小写的Mongo查询

Mongodb 关于字段名不区分大小写的Mongo查询,mongodb,case-insensitive,Mongodb,Case Insensitive,例如: db.stuff.save({"InnerDocument": {"Id":"123"}}); db.stuff.save({"InnerDocument": {"ID":"123"}}); 是否有可能实现以下目标 > db.stuff.find({"InnerDocument.id":"123"}).count(); 2 做那样的事是不容易的。您可以通过mongodb的map reduce框架来实现。这是一个例子: db.stuff.mapReduce( function()

例如:

db.stuff.save({"InnerDocument": {"Id":"123"}});
db.stuff.save({"InnerDocument": {"ID":"123"}});
是否有可能实现以下目标

> db.stuff.find({"InnerDocument.id":"123"}).count();
2

做那样的事是不容易的。您可以通过mongodb的map reduce框架来实现。这是一个例子:

db.stuff.mapReduce(
function(){ 
    var  key = 'id';
    var  value_temp = '123';
    for (i in this['InnerDocument']){
      if (key === i.toLowerCase() && this['InnerDocument'][i] === value_temp){
            emit(key,1);
      }
    }

    },
function(key,value){
    return Array.sum(value);
    },
{out : {inline : 1}}
)['results'][0];

正如这里所提到的,没有这样的操作符。

这是不可能的。您可以执行$或以下查询:

db.stuff.find({$or:[{"InnerDocument.id":"123"}, {"InnerDocument.Id":"123"}, {"InnerDocument.ID":"123"}]}).count();
但那太难看了。我建议您保持数据和字段命名约定的干净性和一致性,这样您就不必这样做