首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >怎么说..。当字段为数字时匹配...在mongodb中?

怎么说..。当字段为数字时匹配...在mongodb中?
EN

Stack Overflow用户
提问于 2012-11-16 10:09:51
回答 8查看 14.3K关注 0票数 14

所以在我的results...the结果中有一个叫做‘城市’的字段,有时它是一个真实的名字,有时它是一个数字。下面的代码显示所有记录...

代码语言:javascript
运行
复制
db.zips.aggregate([{$project : {city:{$substr:["$city",0,1]}}},{$sort : {city : 1}} ])

我需要修改这一行,使其只显示名称为数字(2,3,4等)的城市的记录。....I认为我可以使用'$match',但如何使用呢?

代码语言:javascript
运行
复制
db.zips.aggregate([{$project : {city:{$substr:["$city",0,1]}}},{$sort : {city : 1}}, {$match:{???what_to_say_here???} ]) 

“当城市是数字时匹配”怎么说?

我得到的输出是这样的.

代码语言:javascript
运行
复制
    {
        "city" : "A",
        "_id" : "04465"
    },
    {
        "city" : "1",
        "_id" : "02821"
    },
    {
        "city" : "0",
        "_id" : "04689"
    }

我试图只显示与一个更大的“家庭作业”问题有关的带有数字string...this的记录,但直到我通过这一点,我才能进入实际的家庭作业问题。

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2012-11-16 10:32:49

$match中使用$type运算符

代码语言:javascript
运行
复制
db.zips.aggregate([
    {$project : {city:{$substr:["$city",0,1]}}},
    {$sort : {city : 1}}, 
    {$match: {city: {$type: 16}}}      // city is a 32-bit integer
]);

number没有单一的类型值,因此您需要知道您拥有哪种类型的number:

代码语言:javascript
运行
复制
32-bit integer   16
64-bit integer   18
Double           1

或者使用$or运算符来匹配所有类型的数字:

代码语言:javascript
运行
复制
db.zips.aggregate([
    {$project : {city:{$substr:["$city",0,1]}}},
    {$sort : {city : 1}}, 
    {$match: {$or: [{city: {$type: 1}}, {city: {$type: 16}}, {city: {$type: 18}}]}}
]);

或者甚至使用$not来匹配city不是字符串的所有文档:

代码语言:javascript
运行
复制
db.zips.aggregate([
    {$project : {city:{$substr:["$city",0,1]}}},
    {$sort : {city : 1}}, 
    {$match: {city: {$not: {$type: 2}}}}      // city is not a string
]);

已更新

要匹配city为数字字符串的所有文档,可以使用正则表达式:

代码语言:javascript
运行
复制
db.zips.aggregate([
    {$project : {city:{$substr:["$city",0,1]}}},
    {$sort : {city : 1}}, 
    {$match: {city: /^\d.*$/}}      // city is all digits
]);
票数 30
EN

Stack Overflow用户

发布于 2014-03-09 01:02:06

为什么不使用$regex呢?

代码语言:javascript
运行
复制
db.zips.aggregate([
    {$project : {city:{$substr:["$city",0,1]}}},
    {$sort : {city : 1}}, 
    {$match: {city:{$regex:'[0-9]'}}}
])
票数 19
EN

Stack Overflow用户

发布于 2015-02-07 01:54:37

只需使用:

代码语言:javascript
运行
复制
db.zips.aggregate([
{$match: {
    'city': { $regex: '^[0-9].*'}
}}])

这对我来说很好!

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13409386

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档