MongoDB
 sql >> डेटाबेस >  >> NoSQL >> MongoDB

मोंगोडीबी $घटाना

MongoDB में, आप $subtract . का उपयोग कर सकते हैं एकत्रीकरण पाइपलाइन ऑपरेटर संख्याओं और/या तिथियों को घटाने के लिए।

विशेष रूप से, $subtract निम्नलिखित तीन काम कर सकते हैं:

  • अंतर वापस करने के लिए दो नंबर घटाएं
  • किसी तिथि से एक संख्या घटाएं (मिलीसेकंड में) और परिणामी तिथि लौटाएं
  • मिलीसेकंड में अंतर वापस करने के लिए दो तिथियों को घटाएं

$subtract ऑपरेटर मानों को तर्क के रूप में स्वीकार करता है। तर्क किसी भी मान्य अभिव्यक्ति हो सकते हैं जब तक कि वे संख्याओं और/या तिथियों को हल करते हैं। किसी तारीख से किसी संख्या को घटाने के लिए, तारीख पहला तर्क होना चाहिए..

नमूना डेटा

मान लीजिए हमारे पास data . नामक संग्रह है निम्नलिखित दस्तावेज़ के साथ:

{
	"_id" : 1,
	"a" : 20000,
	"b" : 250,
	"start" : ISODate("2021-01-03T00:00:00Z"),
	"end" : ISODate("2021-01-03T23:30:15.100Z")
}

संख्या घटाएं

हम $subtract . का उपयोग कर सकते हैं a . घटाने के लिए ऑपरेटर b . से फ़ील्ड क्षेत्र (या इसके विपरीत)।

उदाहरण:

db.data.aggregate(
   [
     { $project: { 
       _id: 0,
       a: 1, 
       b: 1, 
       result: { 
         $subtract: [ "$a", "$b" ] } } 
         }
   ]
)

परिणाम:

{ "a" : 20000, "b" : 250, "result" : 19750 }

किसी तारीख से कोई संख्या घटाएं

यदि पहला तर्क एक तिथि है और दूसरा तर्क एक संख्या है, तो $subtract ऑपरेटर तारीख से मिलीसेकंड में संख्या घटाता है।

उदाहरण:

db.data.aggregate(
   [
     { $project: { 
       _id: 0,
       b: 1, 
       start: 1, 
       result: { 
         $subtract: [ "$start", "$b" ] } } 
         }
   ]
).pretty()

परिणाम:

{
	"b" : 250,
	"start" : ISODate("2021-01-03T00:00:00Z"),
	"result" : ISODate("2021-01-02T23:59:59.750Z")
}

हम देख सकते हैं कि 250 मिलीसेकंड को तारीख से घटा दिया गया है।

जब हम किसी तिथि से किसी संख्या को घटाते हैं, तो तारीख को पहला तर्क होना चाहिए और संख्या दूसरे तर्क के रूप में होनी चाहिए।

अगर हम तर्कों को इधर-उधर कर देते हैं तो क्या होता है:

db.data.aggregate(
   [
     { $project: { 
       _id: 0,
       b: 1, 
       start: 1, 
       result: { 
         $subtract: [ "$b", "$start" ] } } 
         }
   ]
).pretty()

परिणाम:

uncaught exception: Error: command failed: {
	"ok" : 0,
	"errmsg" : "cant $subtract adate from a double",
	"code" : 16556,
	"codeName" : "Location16556"
} : aggregate failed :
[email protected]/mongo/shell/utils.js:25:13
[email protected]/mongo/shell/assert.js:18:14
[email protected]/mongo/shell/assert.js:618:17
[email protected]/mongo/shell/assert.js:708:16
[email protected]/mongo/shell/db.js:266:5
[email protected]/mongo/shell/collection.js:1046:12
@(shell):1:1

हमें यह बताते हुए एक त्रुटि मिलती है कि यह किसी तिथि को दोगुने से नहीं घटा सकता।

दो तिथियों के बीच का अंतर लौटाएं

यदि दोनों तर्क दिनांक हैं, तो $subtract ऑपरेटर दो तिथियों के बीच के अंतर को मिलीसेकंड में लौटाता है।

उदाहरण:

db.data.aggregate(
   [
     { $project: { 
       _id: 0,
       start: 1, 
       end: 1,
       result: { 
         $subtract: [ "$end", "$start" ] } } 
         }
   ]
).pretty()

परिणाम:

{
	"start" : ISODate("2021-01-03T00:00:00Z"),
	"end" : ISODate("2021-01-03T23:30:15.100Z"),
	"result" : NumberLong(84615100)
}

यदि हम तारीखों को बदल देते हैं, तो परिणाम एक ऋणात्मक मान बन जाता है:

db.data.aggregate(
   [
     { $project: { 
       _id: 0,
       start: 1, 
       end: 1,
       result: { 
         $subtract: [ "$start", "$end" ] } } 
         }
   ]
).pretty()

परिणाम:

{
	"start" : ISODate("2021-01-03T00:00:00Z"),
	"end" : ISODate("2021-01-03T23:30:15.100Z"),
	"result" : NumberLong(-84615100)
}

तर्कों की गलत संख्या पास करना

$subtract ऑपरेटर ठीक दो तर्क स्वीकार करता है। तर्कों की गलत संख्या पास करने से त्रुटि होती है।

उदाहरण:

db.data.aggregate(
   [
     { $project: { 
       result: { 
         $subtract: [ "$a" ] } } 
         }
   ]
)

परिणाम:

uncaught exception: Error: command failed: {
	"ok" : 0,
	"errmsg" : "Invalid $project :: caused by :: Expression $subtract takes exactly 2 arguments. 1 were passed in.",
	"code" : 16020,
	"codeName" : "Location16020"
} : aggregate failed :
[email protected]/mongo/shell/utils.js:25:13
[email protected]/mongo/shell/assert.js:18:14
[email protected]/mongo/shell/assert.js:618:17
[email protected]/mongo/shell/assert.js:708:16
[email protected]/mongo/shell/db.js:266:5
[email protected]/mongo/shell/collection.js:1046:12
@(shell):1:1

शून्य मान पास करना

दो पासिंग null मानों का परिणाम null होता है लौटाया जा रहा है।

उदाहरण:

db.data.aggregate(
   [
     { $project: { 
       result: { 
         $subtract: [ null, null ] } } 
         }
   ]
)

परिणाम:

{ "_id" : 1, "result" : null }

  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. कई चर के साथ render_template

  2. मोंगोडब आईडी से टाइमस्टैम्प प्राप्त करना

  3. नेवले और तिथियों के साथ पूछताछ

  4. NodeJS और MongoDB FindAndModify () को हटाने या अपडेट करने की आवश्यकता है

  5. एक प्रकाशन दूसरे प्रकाशन से नेस्टेड फ़ील्ड छुपा रहा है