MongoDB チュートリアルlogin
MongoDB チュートリアル
著者:php.cn  更新時間:2022-04-21 17:49:03

MongoDB 条件演算子


説明

条件演算子は、2 つの式を比較し、mongoDB コレクションからデータを取得するために使用されます。

この章では、MongoDB で条件演算子を使用する方法について説明します。

MongoDB の条件演算子は次のとおりです:

  • (>) より大きい - $gt

  • (<) より小さい - $lt

  • (>=) 以上 - $gte

  • (<= ) $lte

使用するデータベース名は「php」、コレクション名は「col」です。 以下は、挿入したデータです。

テストを容易にするために、まず次のコマンドを使用してコレクション「col」のデータをクリアします:

db.col.remove({})

次のデータを挿入します

>db.col.insert({
    title: 'PHP 教程', 
    description: 'PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。',
    by: 'php中文网',
    url: 'http://www.php.cn',
    tags: ['php'],
    likes: 200
})

>db.col.insert({title: 'Java 教程', 
    description: 'Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。',
    by: 'php中文网',
    url: 'http://www.php.cn',
    tags: ['java'],
    likes: 150
})

>db.col.insert({title: 'MongoDB 教程', 
    description: 'MongoDB 是一个 Nosql 数据库',
    by: 'php中文网',
    url: 'http://www.php.cn',
    tags: ['mongodb'],
    likes: 100
})

find() コマンドを使用してデータを表示します。

> db.col.find()
{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "mongodb" ], "likes" : 100 }

MongoDB (> ) より大きい演算子 - $gt

「col」コレクション内の「いいね」が 100 を超えるデータを取得したい場合は、次のコマンドを使用できます。 SQL ステートメント:

db.col.find({"likes" : {$gt : 100}})

出力結果:

Select * from col where likes > 100;

MongoDB (>=) 以上演算子 - $gte

"likes" がより大きい "col" コレクション内のデータを取得したい場合100 以上の場合は、次のコマンドを使用できます:

> db.col.find({"likes" : {$gt : 100}})
{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "java" ], "likes" : 150 }
>

SQL ステートメントと同様:

db.col.find({likes : {$gte : 100}})

出力結果:

Select * from col where likes >=100;

MongoDB (<) 小なり演算子 - $lt

必要な場合「col」コレクション内の「いいね」が 150 未満のデータを取得するには、次のコマンドを使用できます。

> db.col.find({likes : {$gte : 100}})
{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "php" ], "likes" : 200 }
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "mongodb" ], "likes" : 100 }
>

同様に SQL ステートメントの場合:

db.col.find({likes : {$lt : 150}})

出力結果:

Select * from col where likes < 150;

MongoDB (< =) 小なり演算子 - $lte

"col" コレクション内の 150 以下の "いいね" のデータを取得したい場合は、次のコマンドを使用できます:

> db.col.find({likes : {$lt : 150}})
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "mongodb" ], "likes" : 100 }

SQL ステートメントと同様:

db.col.find({likes : {$lte : 150}})

出力結果:

Select * from col where likes <= 150;

(<) と (>) を使用した MongoDB クエリ - $lt と $gt

"col" を取得したい場合 "いいね" が 100 を超えるデータの場合コレクション内に 200 を超える場合は、次のコマンドを使用できます:

> db.col.find({likes : {$lte : 150}})
{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "java" ], "likes" : 150 }
{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "php中文网", "url" : "http://www.php.cn", "tags" : [ "mongodb" ], "likes" : 100 }

SQL ステートメントと同様:

db.col.find({likes : {$lt :200, $gt : 100}})

出力結果:

Select * from col where likes>100 AND  likes<200;