描述

在本章節(jié)中,我們將繼續(xù)討論MongoDB中條件操作符 $type。

$type操作符是基于BSON類型來檢索集合中匹配的數(shù)據(jù)類型,并返回結(jié)果。

MongoDB 中可以使用的類型如下表所示:

類型數(shù)字備注
Double1 
String2 
Object3 
Array4 
Binary data5 
Undefined6已廢棄。
Object id7 
Boolean8 
Date9 
Null10 
Regular Expression11 
JavaScript13 
Symbol14 
JavaScript (with scope)15 
32-bit integer16 
Timestamp17 
64-bit integer18 
Min key255Query with -1.
Max key127 

我們使用的數(shù)據(jù)庫名稱為"php" 我們的集合名稱為"col",以下為我們插入的數(shù)據(jù)。

簡(jiǎn)單的集合"col":

>db.col.insert({
    title: 'PHP 教程', 
    description: 'PHP 是一種創(chuàng)建動(dòng)態(tài)交互性站點(diǎn)的強(qiáng)有力的服務(wù)器端腳本語言。',
    by: 'php中文網(wǎng)',
    url: 'http://miracleart.cn',
    tags: ['php'],
    likes: 200
})

>db.col.insert({title: 'Java 教程', 
    description: 'Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。',
    by: 'php中文網(wǎng)',
    url: 'http://miracleart.cn',
    tags: ['java'],
    likes: 150
})

>db.col.insert({title: 'MongoDB 教程', 
    description: 'MongoDB 是一個(gè) Nosql 數(shù)據(jù)庫',
    by: 'php中文網(wǎng)',
    url: 'http://miracleart.cn',
    tags: ['mongodb'],
    likes: 100
})

使用find()命令查看數(shù)據(jù):

> db.col.find()
{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種創(chuàng)建動(dòng)態(tài)交互性站點(diǎn)的強(qiáng)有力的服務(wù)器端腳本語言。", "by" : "php中文網(wǎng)", "url" : "http://miracleart.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。", "by" : "php中文網(wǎng)", "url" : "http://miracleart.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個(gè) Nosql 數(shù)據(jù)庫", "by" : "php中文網(wǎng)", "url" : "http://miracleart.cn", "tags" : [ "mongodb" ], "likes" : 100 }

MongoDB 操作符 - $type 實(shí)例

如果想獲取 "col" 集合中 title 為 String 的數(shù)據(jù),你可以使用以下命令:

db.col.find({"title" : {$type : 2}})

輸出結(jié)果為:

{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一種創(chuàng)建動(dòng)態(tài)交互性站點(diǎn)的強(qiáng)有力的服務(wù)器端腳本語言。", "by" : "php中文網(wǎng)", "url" : "http://miracleart.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高級(jí)程序設(shè)計(jì)語言。", "by" : "php中文網(wǎng)", "url" : "http://miracleart.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一個(gè) Nosql 數(shù)據(jù)庫", "by" : "php中文網(wǎng)", "url" : "http://miracleart.cn", "tags" : [ "mongodb" ], "likes" : 100 }