Docs Menu
Docs Home
/ /

$gt(式式)

$gt

$gt は、フィールドの値が指定した値(>)を超えるドキュメントを選択します。

比較演算子はほとんどのデータ型で、 BSON 型がクエリ値の型と一致するフィールドに対してのみ比較を実行します。 MongoDB は型のブラケット処理 による限定的な BSON 間比較をサポートします。

次の環境でホストされる配置には $gt を使用できます。

  • MongoDB Atlas はクラウドでの MongoDB 配置のためのフルマネージド サービスです

  • MongoDB Enterprise: サブスクリプションベースの自己管理型 MongoDB バージョン

  • MongoDB Community: ソースが利用可能で、無料で使用できる自己管理型の MongoDB のバージョン

$gt 演算子の形式は次のとおりです。

{ field: { $gt: value } }

例で使われている inventory コレクションを作成するには、次のコマンドを実行します:

db.inventory.insertMany( [
{
item: "nuts", quantity: 30,
carrier: { name: "Shipit", fee: 3 }
},
{
item: "bolts", quantity: 50,
carrier: { name: "Shipit", fee: 4 }
},
{
item: "washers", quantity: 10,
carrier: { name: "Shipit", fee: 1 }
}
] )

この例では、inventory コレクションの中で、quantity20 よりも大きいドキュメントを選択しています。

db.inventory.find( { quantity: { $gt: 20 } } )

出力例:

{
_id: ObjectId("61ba25cbfe687fce2f042414"),
item: 'nuts',
quantity: 30,
carrier: { name: 'Shipit', fee: 3 }
},
{
_id: ObjectId("61ba25cbfe687fce2f042415"),
item: 'bolts',
quantity: 50,
carrier: { name: 'Shipit', fee: 4 }
}

この例では、埋め込みドキュメント内のフィールドと $gt の比較に基づき price フィールドを設定します。

db.inventory.updateOne(
{ "carrier.fee": { $gt: 2 } }, { $set: { "price": 9.99 } }
)

出力例:

{
_id: ObjectId("61ba3ec9fe687fce2f042417"),
item: 'nuts',
quantity: 30,
carrier: { name: 'Shipit', fee: 3 },
price: 9.99
},
{
_id: ObjectId("61ba3ec9fe687fce2f042418"),
item: 'bolts',
quantity: 50,
carrier: { name: 'Shipit', fee: 4 }
},
{
_id: ObjectId("61ba3ec9fe687fce2f042419"),
item: 'washers',
quantity: 10,
carrier: { name: 'Shipit', fee: 1 }
}

updateOne() 操作は、名前が carrier の埋め込みドキュメントと、サブフィールド名が fee のフィールドにマッチします。操作は、最初のドキュメントで { price: 9.99 } を設定し、fee2 より大きい場合に適用されます。

carrier.fee2より大きいすべてのドキュメントでpriceフィールドを設定するには、updateMany()を使用します。

戻る

$eq

項目一覧