我正在寻找一个操作符,它允许我检查字段的值是否包含某个字符串。

喜欢的东西:

db.users.findOne({$contains:{"username":"son"}})

这可能吗?


当前回答

您可以使用以下代码来实现。

db.users.findOne({"username" : {$regex : "son"}});

其他回答

您可以使用以下代码来实现。

db.users.findOne({"username" : {$regex : "son"}});

下面是通过Python连接MongoDB时必须做的事情

db.users.find({"username": {'$regex' : '.*' + 'Son' + '.*'}})

你也可以使用一个变量名来代替'Son',因此字符串连接。

我使用这个代码,它的工作搜索子字符串

db.users.find({key: { $regex: new RegExp(value, 'i')}})

理想答案其使用指标 I选项不区分大小写

db.users.findOne({"username" : new RegExp(search_value, 'i') });

如果正则表达式在聚合解决方案中不起作用,并且您有嵌套对象。试试这个聚合管道:(如果你的对象结构很简单,只需从下面的查询中删除其他条件):

db.user.aggregate({$match: 
     {$and:[
   {"UserObject.Personal.Status":"ACTV"},
   {"UserObject.Personal.Address.Home.Type":"HME"},
   {"UserObject.Personal.Address.Home.Value": /.*son.*/ }
   ]}}
   ) 

另一种方法是像这样直接查询:

db.user.findOne({"UserObject.Personal.Address.Home.Value": /.*son.*/ });