$mod - Amazon DocumentDB

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

$mod

$mod 運算子是對數字執行模數操作的算術運算子。它會傳回將一個數字除以另一個數字的其餘部分。此運算子通常用於判斷數字是奇數還是偶數,或將項目分配到有限數量的群組。

參數

  • expression1:分配表達式。

  • expression2:除數表達式。

範例 (MongoDB Shell)

此範例示範如何在以 100 個套件運送時,使用 $mod 運算子來判斷剩餘小工具的數量。

建立範例文件

db.widgets.insertMany([ { "_id" : 1, "widget" : "A", "count" : 80372 }, { "_id" : 2, "widget" : "B", "count" : 409282 }, { "_id" : 3, "widget" : "C", "count" : 60739 } ])

查詢範例

db.widgets.aggregate([ { $addFields: { leftOver: { $mod: [ "$count", 100 ] } } } ])

輸出

[ { "_id" : 1, "widget" : "A", "count" : 80372, "leftOver" : 72 }, { "_id" : 2, "widget" : "B", "count" : 409282, "leftOver" : 82 }, { "_id" : 3, "widget" : "C", "count" : 60739, "leftOver" : 39 } ]

輸出顯示每個文件的其餘count部分除以 100,代表以 100 套件運送時剩餘的小工具數量。

程式碼範例

若要檢視使用 $mod命令的程式碼範例,請選擇您要使用的語言標籤:

Node.js
const { MongoClient } = require('mongodb'); async function main() { const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false'); const db = client.db('test'); const widgets = db.collection('widgets'); await widgets.insertMany([ { "_id" : 1, "widget" : "A", "count" : 80372 }, { "_id" : 2, "widget" : "B", "count" : 409282 }, { "_id" : 3, "widget" : "C", "count" : 60739 } ]); const result = await widgets.aggregate([ { $addFields: { leftOver: { $mod: [ "$count", 100 ] } } } ]).toArray(); console.log(result); client.close(); } main();
Python
from pymongo import MongoClient client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false') db = client['test'] widgets = db['widgets'] widgets.insert_many([ { "_id" : 1, "widget" : "A", "count" : 80372 }, { "_id" : 2, "widget" : "B", "count" : 409282 }, { "_id" : 3, "widget" : "C", "count" : 60739 } ]) result = list(widgets.aggregate([ { "$addFields": { "leftOver": { "$mod": [ "$count", 100 ] } } } ])) print(result) client.close()