PouchDB - त्वरित गाइड

यह अध्याय अपनी विशेषताओं और यह कैसे काम करता है, इसके साथ ही PouchDB का संक्षिप्त परिचय प्रदान करता है।

PouchDB क्या है?

PouchDB एक खुला स्रोत है in-browser database APIजावास्क्रिप्ट में लिखा है। यह काउच डीबी और मिनस के बाद बनाया गया है ; एक NoSQL डेटाबेस। इस एपीआई का उपयोग करके, हम उन अनुप्रयोगों का निर्माण कर सकते हैं जो ऑफ़लाइन और ऑनलाइन काम करते हैं। यह डेटा को संग्रहीत करने के लिए WebSQL और IndexedDB का आंतरिक रूप से उपयोग करता है।

यह कैसे काम करता है?

PouchDB में, जब एप्लिकेशन ऑफ़लाइन होता है, तो डेटा को ब्राउज़र में WebSQL और IndexedDB का उपयोग करके स्थानीय रूप से संग्रहीत किया जाता है। जब एप्लिकेशन ऑनलाइन वापस आ जाता है, तो इसे CouchDB और संगत सर्वर के साथ सिंक्रनाइज़ किया जाता है।

PouchDB का उपयोग करते हुए, आप किसी भी अंतर को देखे बिना, स्थानीय और दूरस्थ डेटाबेस दोनों के साथ संचार कर सकते हैं।

PouchDB की सुविधाएँ

PouchDB की विशेषताएं निम्नलिखित हैं -

  • Cross Browser - PouchDB द्वारा प्रदान किया गया API हर वातावरण में समान काम करता है, इसलिए, हम विभिन्न ब्राउज़रों में PouchDB एप्लिकेशन चला सकते हैं।

  • Light Weight - PouchDB एक बहुत ही हल्के वजन वाला एपीआई है, यह भी एक स्क्रिप्ट टैग का उपयोग करके आसानी से शामिल है।

  • Easy to Learn - अगर आपको किसी प्रोग्रामिंग लैंग्वेज की पूर्व जानकारी है, तो PouchDB सीखना आसान है।

  • Open Source - PouchDB एक ओपन सोर्स एप्लिकेशन है और GitHub पर उपलब्ध है।

PouchDB के लाभ

PouchDB के फायदे निम्नलिखित हैं -

  • चूंकि PouchDB ब्राउज़र के अंदर रहता है, इसलिए नेटवर्क पर प्रश्नों को करने की कोई आवश्यकता नहीं है, इससे प्रश्नों का तेजी से निष्पादन होता है।

  • आप किसी भी समर्थित सर्वर के साथ डेटा को सिंक्रनाइज़ कर सकते हैं और ऐसा करके आप ऑनलाइन और ऑफलाइन दोनों तरह से ऐप चला सकते हैं।

ब्राउज़र जो PouchDB का समर्थन करते हैं

निम्नलिखित ब्राउज़र हैं जो PouchDB का समर्थन करते हैं -

  • फ़ायरफ़ॉक्स 29+ (एंड्रॉइड के लिए फ़ायरफ़ॉक्स ओएस और फ़ायरफ़ॉक्स सहित)
  • क्रोम 30+
  • सफारी 5+
  • इंटरनेट एक्सप्लोरर 10+
  • ओपेरा 21+
  • Android 4.0+
  • iOS 7.1+
  • विंडोज फोन 8+

यह अध्याय बताता है कि अपने सिस्टम में PouchDB कैसे डाउनलोड करें और इंस्टॉल करें।

PouchDB स्थापित करना

PouchDB के साथ काम करने के लिए, आपको फ़ाइल डाउनलोड करने की आवश्यकता है .jsफ़ाइल और अपनी स्क्रिप्ट में शामिल करें। PouchDB स्थापित करने के लिए निम्नलिखित चरण हैं।

चरण 1

निम्नलिखित लिंक पर क्लिक करके, PouchDB वेबसाइट के होमपेज पर जाएं -

https://PouchDB.com/

चरण 2

उपरोक्त स्क्रीनशॉट में दिखाए अनुसार वेब पेज के ऊपरी दाएँ हाथ की ओर स्थित डाउनलोड बटन पर क्लिक करें। यह डाउनलोड करेगाPouchDB-5.3.0.min.js आपके सिस्टम में

चरण 3

कॉपी और पेस्ट करें PouchDB-5.3.0.min.js अपनी कार्यशील निर्देशिका में और इसे अपने जावास्क्रिप्ट में शामिल करें जैसा कि निम्नलिखित कमांड में दिखाया गया है।

<script src = "PouchDB-5.3.0.min.js"></script>

Node.js का उपयोग करके थैली स्थापित करना

आप PouchDB को Node.js मॉड्यूल के रूप में भी स्थापित कर सकते हैं। Node.js. का उपयोग करके PouchDB स्थापित करने के लिए निम्नलिखित चरण हैं

चरण 1

हमारे कॉफी स्क्रिप्ट ट्यूटोरियल के इंस्टॉलेशन Node.js अनुभाग में दिए गए चरणों का पालन करके Node.js स्थापित करें ।

चरण 2

कमांड प्रॉम्प्ट खोलें और निम्न कमांड निष्पादित करें। यह आपके सिस्टम में PouchDB नोड मॉड्यूल स्थापित करेगा।

npm install --save PouchDB

CouchDB डाउनलोड करना

ऑफ़लाइन होने पर, PouchDB स्थानीय रूप से डेटा संग्रहीत करता है और एक ऐप की तरह काम करता है। आप इसे संगत सर्वर से जोड़कर ऑनलाइन एक्सेस कर सकते हैं। जैसा कि हम जानते हैं कि PouchDB CouchDB से जुड़ा जा सकता है, इसलिए, CouchDB भी स्थापित करने देता है। CouchDB स्थापित करने के लिए निम्नलिखित चरण हैं।

चरण 1

CouchDB के लिए आधिकारिक वेबसाइट है http://couchdb.apache.org। यदि आप दिए गए लिंक पर क्लिक करते हैं, तो आप CouchDB आधिकारिक वेबसाइट का होम पेज प्राप्त कर सकते हैं जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

चरण 2

यदि आप डाउनलोड बटन पर क्लिक करते हैं जो एक पृष्ठ पर ले जाएगा जहां विभिन्न स्वरूपों में CouchDB के डाउनलोड लिंक दिए गए हैं। निम्न स्नैपशॉट समान दिखाता है।

चरण 3

विंडोज सिस्टम के लिए डाउनलोड लिंक चुनें और अपना डाउनलोड शुरू करने के लिए दिए गए दर्पणों में से एक का चयन करें।

CouchDB स्थापित करना

एक विंडोज़ निष्पादन योग्य setup-couchdb-1.6.1_R16B02.exeफ़ाइल आपके सिस्टम पर डाउनलोड हो जाएगी। सेटअप फ़ाइल चलाएँ और स्थापना के साथ आगे बढ़ें।

अपने सिस्टम में CouchDB सफलतापूर्वक स्थापित करने के बाद, CouchDB स्थापित किया गया फ़ोल्डर खोलें, बिन फ़ोल्डर पर जाएँ, और स्क्रिप्ट नाम से स्क्रिप्ट फ़ाइल चलाकर सर्वर को प्रारंभ करें couchdb.bat

स्थापना के बाद, निम्न लिंक पर जाकर CouchDB का अंतर्निहित वेब इंटरफ़ेस खोलें - http://127.0.0.1:5984/। यदि सब कुछ ठीक हो जाता है, तो यह आपको एक वेब पेज देगा, जिसमें निम्नलिखित आउटपुट होंगे।

{                 
   "couchdb":"Welcome","uuid":"c8d48ac61bb497f4692b346e0f400d60",
   "version":"1. 6.1",
   "vendor": {
      "version":"1.6.1","name":"The Apache Software Foundation"
   } 
}

आप निम्नलिखित URL का उपयोग करके CouchDB वेब इंटरफ़ेस के साथ बातचीत कर सकते हैं -

http://127.0.0.1:5984/_utils/

यह आपको Futon का इंडेक्स पेज दिखाता है, जो CouchDB का वेब इंटरफेस है।

आप PouchDB कंस्ट्रक्टर का उपयोग करके PouchDB में एक डेटाबेस बना सकते हैं।

वाक्य - विन्यास

निम्नलिखित PouchDB कंस्ट्रक्टर का उपयोग करने का सिंटैक्स है। इसके लिए, आपको डेटाबेस के नाम को एक पैरामीटर के रूप में पास करना होगा।

new PouchDB(Database_name)

उदाहरण

का उपयोग कर PouchDB में एक डेटाबेस बनाने के लिए nodeसबसे पहले, आपको PouchDB पैकेज का उपयोग करने की आवश्यकता है require() विधि और फिर आप एक डेटाबेस बना सकते हैं जैसा कि निम्नलिखित उदाहरण में दिखाया गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');
console.log ("Database created Successfully.");

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Create_Database.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples>node Create_Database.js

यह स्थानीय रूप से एक डेटाबेस बनाएगा (आप मौजूदा निर्देशिका में फ़ोल्डर देख सकते हैं) निम्नलिखित संदेश प्रदर्शित करते हैं।

Database created Successfully.

आप नामांकित विधि का उपयोग करके डेटाबेस के बारे में मूल जानकारी प्राप्त कर सकते हैं info()

वाक्य - विन्यास

निम्नलिखित का उपयोग करने का वाक्यविन्यास है info()पाउचडीबी की विधि। यह विधि कॉलबैक फ़ंक्शन को स्वीकार करती है।

db.info([callback])

उदाहरण

निम्नलिखित डेटाबेस जानकारी प्राप्त करने का एक उदाहरण है जिसका उपयोग कर रहा है info()तरीका। यहां, हम नामित डेटाबेस की जानकारी प्रदर्शित कर रहे हैंmy_database। त्रुटि के मामले में, त्रुटि कंसोल पर प्रदर्शित की जाएगी।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Database information
db.info(function(err, info) {
   if (err) {
      return console.log(err);
   } else {
      console.log(info);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Database_info.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples>node Database_info.js

यह निर्दिष्ट डेटाबेस की जानकारी निम्नानुसार प्रदर्शित करेगा।

{ 
   doc_count: 0,
   update_seq: 0,
   backend_adapter: 'LevelDOWN',
   db_name: 'my_database',
   auto_compaction: false,
   adapter: 'leveldb' 
}

दूरस्थ डेटाबेस जानकारी

उसी तरह, आपको एक डेटाबेस की जानकारी मिलती है जिसे सर्वर (CouchDB) पर दूरस्थ रूप से सहेजा जाता है। ऐसा करने के लिए, डेटाबेस के नाम के बजाय, आपको CouchDB में आवश्यक डेटाबेस के लिए मार्ग पास करना होगा।

उदाहरण

निम्नलिखित एक डेटाबेस की जानकारी प्राप्त करने का एक उदाहरण है जो CouchDB सर्वर में सहेजा गया है। यह कोड आपको नामित डेटाबेस की जानकारी देता हैmy_database

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Database information
db.info(function(err, info) {
   if (err) {
      return console.log(err);
   } else {
      console.log(info);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Database_ Remote_info.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples>node Database_Remote_info.js

यह निर्दिष्ट डेटाबेस की जानकारी निम्नानुसार प्रदर्शित करेगा।

{ 
   db_name: 'my_database', 
   doc_count: 0, 
   doc_del_count: 0, 
   update_seq: 0, 
   purge_seq: 0, 
   compact_running: false, 
   disk_size: 79, 
   data_size: 0, 
   instance_start_time: '1458209191708486', 
   disk_format_version: 6, 
   committed_update_seq: 0, 
   host: 'http://localhost:5984/my_database/', 
   auto_compaction: false, 
   adapter: 'http' 
}

आप का उपयोग करके PouchDB में एक डेटाबेस को हटा सकते हैं db.destroy() तरीका।

वाक्य - विन्यास

निम्नलिखित का उपयोग करने का वाक्यविन्यास है db.destroy()तरीका। यह विधि एक पैरामीटर के रूप में कॉलबैक फ़ंक्शन को स्वीकार करती है।

db.destroy()

उदाहरण

निम्नलिखित का उपयोग करके PouchDB में एक डेटाबेस को हटाने का एक उदाहरण है destroy()तरीका। यहां, हम नाम के डेटाबेस को हटा रहे हैंmy_database, पिछले अध्यायों में बनाया गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//deleting database
db.destroy(function (err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log ("Database Deleted”);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Delete_Database.js. कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करें node जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Delete_Database.js

यह नाम वाले डेटाबेस को हटा देगा my_database जो स्थानीय रूप से निम्न संदेश प्रदर्शित करता है।

Database Deleted

दूरस्थ डेटाबेस हटाना

उसी तरह, आप सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत डेटाबेस को हटा सकते हैं।

ऐसा करने के लिए, डेटाबेस नाम के बजाय, आपको CouchDB में हटाए जाने वाले डेटाबेस के लिए पथ को पारित करने की आवश्यकता है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

निम्नलिखित नाम के डेटाबेस को हटाने का एक उदाहरण है my_database CouchDB सर्वर में सहेजा गया है।

//Requiring the package
var PouchDB = require('pouchdb');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//deleting database
db.destroy(function (err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Database Deleted");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Database_Delete.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >Remote_Database_Delete.js

यह निम्नलिखित संदेश प्रदर्शित करने वाले PouchDB से निर्दिष्ट डेटाबेस को हटाता है।

Database Deleted

सत्यापन

उपरोक्त कार्यक्रम को निष्पादित करने के बाद, यदि आप फिर से URL पर जाते हैं, तो आपको निम्न स्क्रीनशॉट मिलेगा। यहाँ आप केवल दो डेटाबेस का निरीक्षण कर सकते हैंmy_database हटाया गया था।

आप का उपयोग करके PouchDB में एक दस्तावेज़ बना सकते हैं db.put() तरीका।

वाक्य - विन्यास

PouchDB के db.put () पद्धति का उपयोग करने का सिंटैक्स निम्नलिखित है। आप PouchDB में बनाए जाने वाले दस्तावेज़ को एक चर में संग्रहीत कर सकते हैं और इस विधि के लिए एक पैरामीटर के रूप में पास कर सकते हैं। इसके अलावा, यह विधि एक पैरामीटर के रूप में कॉलबैक (वैकल्पिक) फ़ंक्शन को भी स्वीकार करती है।

db.put(document, callback)

उदाहरण

निम्नलिखित का उपयोग करके PouchDB में एक दस्तावेज़ बनाने का एक उदाहरण है put()तरीका। हम जो दस्तावेज़ बनाते हैं वह JSON फॉर्मेट का होना चाहिए, जो किमा द्वारा अलग किए गए की-वैल्यू पेयर का एक सेट है (,) और घुंघराले ब्रेस के भीतर संलग्न ({})।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Preparing the document
doc = {
   _id : '001',
   name: 'Raju',
   age : 23,
   designation : 'Designer'
   }
//Inserting Document
db.put(doc, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Document created Successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Create_Document.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Create_Document.js

यह PouchDB डेटाबेस में दिए गए दस्तावेज़ को नामित करता है my_database, जो स्थानीय रूप से संग्रहीत है, निम्न संदेश प्रदर्शित करता है।

Document created Successfully

किसी दूरस्थ डेटाबेस में दस्तावेज़ सम्मिलित करना

आप डेटाबेस में एक दस्तावेज़ भी डाल सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत होता है।

ऐसा करने के लिए, डेटाबेस नाम के बजाय आपको उस डेटाबेस को पथ को पास करना होगा जहां आप CouchDB में दस्तावेज़ बनाना चाहते हैं।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

अब, यदि आप नामित डेटाबेस पर क्लिक करते हैं my_database, आपको एक खाली डेटाबेस मिलेगा जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

निम्नलिखित एक डेटाबेस नाम में एक दस्तावेज़ सम्मिलित करने का एक उदाहरण है my_database CouchDB सर्वर में सहेजा गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Preparing the document
doc = {
   _id : '001',
   name: 'Raju',
   age : 23,
   designation : 'Designer'
   }
//Inserting Document
db.put(doc, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Document created Successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Create_Document.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Create_Document.js

यह PouchDB डेटाबेस में दिए गए दस्तावेज़ को नामित करता है my_database जो निम्न संदेश प्रदर्शित करते हुए CouchDB में संग्रहीत किया जाता है।

Document created Successfully

सत्यापन

उपरोक्त कार्यक्रम को निष्पादित करने के बाद, यदि आप पर जाएँ my_database फिर से, आप निम्न स्क्रीनशॉट में दिखाए गए अनुसार बनाए गए दस्तावेज़ का निरीक्षण कर सकते हैं।

आप PouchDB का उपयोग करके किसी दस्तावेज़ की सामग्री को पढ़ / प्राप्त कर सकते हैं db.get() तरीका।

वाक्य - विन्यास

निम्नलिखित का उपयोग करने का वाक्यविन्यास है db.get()पाउचडीबी की विधि। यह विधि स्वीकार करती हैdocument id और एक वैकल्पिक कॉलबैक फ़ंक्शन।

db.get(document, callback)

उदाहरण

निम्नलिखित का उपयोग करके PouchDB में एक दस्तावेज़ की सामग्री को पढ़ने का एक उदाहरण है get() तरीका।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Reading the contents of a Document
db.get('001', function(err, doc) {
   if (err) {
      return console.log(err);
   } else {
      console.log(doc);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Read_Document.js। कमांड प्रॉम्प्ट खोलें और नीचे दिखाए अनुसार नोड का उपयोग करके जावास्क्रिप्ट फ़ाइल को निष्पादित करें।

C:\PouchDB_Examples >node Read_Document.js

यह दिए गए दस्तावेज़ की सामग्री को पढ़ता है जो नामांकित डेटाबेस में मौजूद है my_databaseजिसे स्थानीय स्तर पर संग्रहीत किया जाता है। कंसोल पर निम्न संदेश प्रदर्शित होता है।

{
   name: 'Raju',
   age: 23,
   designation: 'Designer',
   _id: '001',
   _rev: '1-ba7f6914ac80098e6f63d2bfb0391637'
}

एक दूरस्थ डेटाबेस से एक दस्तावेज़ पढ़ना

आप डेटाबेस से एक दस्तावेज़ भी पढ़ सकते हैं जिसे सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत किया जाता है।

ऐसा करने के लिए, डेटाबेस नाम के बजाय, आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें पढ़ा जाना है।

उदाहरण

मान लीजिए, नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

नाम के डेटाबेस पर क्लिक करके my_databaseआप निम्न स्क्रीनशॉट देख सकते हैं। यहां, आप देख सकते हैं कि इस डेटाबेस में आईडी के साथ एक दस्तावेज है001

निम्नलिखित दस्तावेज की सामग्री को पढ़ने का एक उदाहरण है, जो आईडी के रूप में है।001“नाम के डेटाबेस में मौजूद है my_database, जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Reading the contents of a document
db.get('001', function(err, doc) {
   if (err) {
      return console.log(err);
   } else {
      console.log(doc);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Read_Document.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Read_Document.js

यह दिए गए दस्तावेज़ की सामग्री को पढ़ता है जो नामांकित डेटाबेस में मौजूद है my_databaseजो CouchDB में संग्रहीत है। कंसोल पर निम्न संदेश प्रदर्शित होता है।

{ 
   _id: '001',
   _rev: '3-552920d1ca372986fad7b996ce365f5d',
   name: 'Raju',
   age: 23,
   designation: 'Designer' 
}

जब भी, हम एक नए क्षेत्र PouchDB में एक दस्तावेज़ बनाते हैं _rev उत्पन्न होता है, और इसे के रूप में जाना जाता है revision marker_revहर बार एक अद्वितीय यादृच्छिक संख्या होती है, जब हम दस्तावेज़ में मूल्य में बदलाव करते हैं _rev बदल गया है।

आप का उपयोग करके PouchDB में एक मौजूदा दस्तावेज़ को अपडेट कर सकते हैं (_rev)। ऐसा करने के लिए, सबसे पहले पुनः प्राप्त करें_revउस दस्तावेज़ का मूल्य जिसे हम अपडेट करना चाहते हैं। अब, उन सामग्रियों को रखें जिन्हें पुनर्प्राप्त करने के साथ अद्यतन किया जाना है_rev एक नए दस्तावेज़ में मूल्य, और अंत में इस दस्तावेज़ को PouchDB का उपयोग करके सम्मिलित करें put() तरीका।

उदाहरण

मान लें कि हमारे पास आईडी के साथ PouchDB में एक दस्तावेज़ है 001जिसमें किसी व्यक्ति का विवरण हो। इस दस्तावेज़ को अद्यतन करने के लिए, हमारे पास इसकी संख्या होनी चाहिए। इसलिए, दस्तावेज़ की सामग्री को पुनः प्राप्त करने के लिए निम्न कोड का उपयोग किया जाता है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Reading the contents of a Document
db.get('001', function(err, doc) {
   if (err) {
      return console.log(err);
   } else {
      console.log(doc);
   }
});

उपरोक्त कोड निष्पादित करने पर, आपको निम्न आउटपुट प्राप्त होगा।

{
   _id: '001',
   _rev: '3-552920d1ca372986fad7b996ce365f5d',
   name: 'Raju',
   age: 23,
   designation: 'Designer' 
}

अब, का उपयोग कर _rev आप कुंजी के मूल्य को अपडेट कर सकते हैं ”age“26 तक, जैसा कि निम्नलिखित कोड में दिखाया गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Preparing the document for update
doc = {
   age: 26,
   _rev: '3-552920d1ca372986fad7b996ce365f5d',
   }

//Inserting Document
db.put(doc);

//Reading the contents of a Document
db.get('001', function(err, doc) {
   if (err) {
      return console.log(err);
   } else {
      console.log(doc);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Update_Document.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\Pouch_Examples>node Update_Document.js

यह दिए गए दस्तावेज़ की सामग्री को अद्यतन करता है जो नामांकित डेटाबेस में मौजूद है my_databaseजिसे स्थानीय स्तर पर संग्रहीत किया जाता है। कंसोल पर निम्न संदेश प्रदर्शित होता है।

{ 
   name: 'Raju',
   age: 26,
   designation: 'Designer',
   _id: '001',
   _rev: '2-61b523ccdc4e41a8435bdffbb057a7a5' 
}

एक दूरस्थ डेटाबेस में एक दस्तावेज़ को अद्यतन करना

आप एक मौजूदा दस्तावेज़ को डेटाबेस में भी अपडेट कर सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत है।

ऐसा करने के लिए, डेटाबेस नाम के बजाय आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें अपडेट किया जाना है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

नाम के डेटाबेस पर क्लिक करके my_database, आप निम्नलिखित स्क्रीनशॉट देख सकते हैं। यहां, आप देख सकते हैं कि इस डेटाबेस में आईडी के साथ एक दस्तावेज है001

निम्नलिखित दस्तावेज़ की आयु को आईडी के रूप में अपडेट करने का एक उदाहरण है "001“नाम के डेटाबेस में मौजूद है my_database जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Preparing the document for update
doc = {
   age: 26,
   _rev: '3-552920d1ca372986fad7b996ce365f5d',
   }

//Inserting Document
db.put(doc);

//Reading the contents of a Document
db.get('001', function(err, doc) {
   if (err) {
      return console.log(err);
   } else {
      console.log(doc);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Update_Document.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Update_Document.js

यह दिए गए दस्तावेज़ की सामग्री को अद्यतन करता है जो नामांकित डेटाबेस में मौजूद है my_databaseजो CouchDB में संग्रहीत है। कंसोल पर निम्न संदेश प्रदर्शित होता है।

{
   _id: '001',
   _rev: '2-b9640bffbce582c94308905eed8bb545',
   name: 'Raju',
   age: 26,
   designation: 'Designer' 
}

आप किसी डेटाबेस से उस दस्तावेज़ को हटा सकते हैं जो PouchDB में मौजूद है db.remove() तरीका।

वाक्य - विन्यास

निम्नलिखित का उपयोग करने का वाक्यविन्यास है db.remove()पाउचडीबी की विधि। इस पद्धति के लिए, हमें पास करना होगाid तथा _revमौजूदा कोड को हटाने के लिए निम्न कोड में दिखाया गया है। यह विधि एक वैकल्पिक कॉलबैक फ़ंक्शन को स्वीकार करती है। हम id और _rev के बजाय पूरा दस्तावेज भी पास कर सकते हैं।

db. get ( docId, docRev, [callback] )
or
db. get ( docId, docRev, [callback] )

उदाहरण

मान लें कि हमारे पास आईडी के साथ PouchDB में एक दस्तावेज़ है 001जिसमें किसी व्यक्ति का विवरण हो। इस दस्तावेज़ को इसके साथ हटाने के लिएid हमें भी इसका होना चाहिए _revनंबर। इसलिए, दस्तावेज़ की सामग्री को पुनः प्राप्त करें जैसा कि निम्नलिखित कोड में दिखाया गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Reading the contents of a Document
db.get('001', function(err, doc) {
   if (err) {
      return console.log(err);
   } else {
      console.log(doc);
   }
});

उपरोक्त कोड का निष्पादन निम्नलिखित आउटपुट देता है।

{
   _id: '001',
   _rev: '3-552920d1ca372986fad7b996ce365f5d',
   name: 'Raju',
   age: 23,
   designation: 'Designer' 
}

अब, का उपयोग कर _rev और दस्तावेज़ की आईडी आप इसे हटाकर उपयोग कर सकते हैं remove() विधि निम्न कोड में दिखाया गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Deleting an existing document
db.remove('001', '3-552920d1ca372986fad7b996ce365f5d', function(err) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Document deleted successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Delete_Document.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Delete_Document.js

यह दिए गए दस्तावेज़ की सामग्री को हटाता है जो नामांकित डेटाबेस में मौजूद है my_databaseजिसे स्थानीय स्तर पर संग्रहीत किया जाता है। निम्न संदेश प्रदर्शित होता है।

Document deleted successfully

किसी दूरस्थ डेटाबेस से कोई दस्तावेज़ हटाना

आप डेटाबेस से मौजूदा दस्तावेज़ भी हटा सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत है।

ऐसा करने के लिए, डेटाबेस नाम के बजाय, आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें पढ़ा जाना है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

नाम के डेटाबेस पर क्लिक करके my_databaseआप निम्न स्क्रीनशॉट देख सकते हैं। यहां, आप देख सकते हैं कि डेटाबेस में आईडी के साथ एक दस्तावेज है001

निम्नलिखित आईडी की सामग्री को हटाने का एक उदाहरण है “001“नाम के डेटाबेस में मौजूद है my_database जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Deleting an existing document
db.remove('001', '3-552920d1ca372986fad7b996ce365f5d', function(err) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Document deleted successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Delete_Document.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Delete_Document.js

यह दिए गए दस्तावेज़ को हटाता है जो नामांकित डेटाबेस में मौजूद है my_databaseजो CouchDB में संग्रहीत है। निम्न संदेश प्रदर्शित होता है।

Document deleted successfully

आप PouchDB का उपयोग करके दस्तावेज़ों की एक सरणी (बैच) बना सकते हैं db.bulkDocs()तरीका। दस्तावेज़ बनाते समय, इस पद्धति का उपयोग करते हुए अगर हम _id मान प्रदान नहीं करते हैं, तो हमारी ओर से PouchDB बल्क में सभी दस्तावेज़ों के लिए अद्वितीय आईडी बनाता है।

वाक्य - विन्यास

निम्नलिखित का उपयोग करने का वाक्यविन्यास है db.bulkDocs()पाउचडीबी की विधि। आप उन सभी दस्तावेज़ों को संग्रहीत कर सकते हैं जिन्हें एक सरणी में PouchDB में बनाया जाना है और इसे एक पैरामीटर के रूप में इस विधि में पास करना है। इसके अतिरिक्त, यह विधि एक पैरामीटर के रूप में कॉलबैक (वैकल्पिक) फ़ंक्शन को भी स्वीकार करती है।

db.bulkDocs(docs, [options], [callback])

उदाहरण

निम्नलिखित का उपयोग करके PouchDB में कई दस्तावेज़ बनाने का एक उदाहरण है db.bulkDocs ()तरीका। हम जो दस्तावेज़ बनाते हैं, वह JSON प्रारूप का होना चाहिए, अल्पविराम द्वारा अलग किए गए कुंजी-मूल्य जोड़े का एक सेट (,) और घुंघराले ब्रेस के भीतर संलग्न ({})।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Preparing the documents array
doc1 = {_id: '001', name: 'Ram', age: 23, Designation: 'Programmer'}
doc2 = {_id: '002', name: 'Robert', age: 24, Designation: 'Programmer'}
doc3 = {_id: '003', name: 'Rahim', age: 25, Designation: 'Programmer'}
docs = [doc1, doc2, doc3]

//Inserting Documents
db.bulkDocs(docs, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Documents created Successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Create_Batch.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Create_Batch.js

यह PouchDB डेटाबेस में दिए गए दस्तावेज़ को नामित करता है my_databaseजिसे स्थानीय स्तर पर संग्रहीत किया जाता है। निम्न संदेश प्रदर्शित होता है।

Documents created Successfully

एक दूरस्थ डेटाबेस में एक बैच सम्मिलित करना

आप डेटाबेस में दस्तावेज़ों की एक सरणी सम्मिलित कर सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत है।

ऐसा करने के लिए, डेटाबेस नाम के बजाय आपको उस डेटाबेस को पथ को पास करना होगा जहां हम CouchDB में दस्तावेज़ बनाना चाहते हैं।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

निम्नलिखित नाम डेटाबेस में दस्तावेजों की एक सरणी डालने का एक उदाहरण है my_database जो CouchDB सर्वर में सहेजा गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Preparing the documents array

doc1 = {_id: '001', name: 'Ram', age: 23, Designation: 'Programmer'}
doc2 = {_id: '002', name: 'Robert', age: 24, Designation: 'Programmer'}
doc3 = {_id: '003', name: 'Rahim', age: 25, Designation: 'Programmer'}

docs = [doc1, doc2, doc3]

//Inserting Documents
db.bulkDocs(docs, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Documents created Successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Create_Batch.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Create_Batch.js

यह दिए गए दस्तावेज़ों को नामित PouchDB डेटाबेस में बनाता है my_databaseजो CouchDB में संग्रहीत है। निम्न संदेश प्रदर्शित होता है।

Document created Successfully

सत्यापन

उपरोक्त कार्यक्रम को क्रियान्वित करने के बाद यदि आप my_database फिर से, आप निम्न स्क्रीनशॉट में दिखाए अनुसार बनाए गए दस्तावेजों का अवलोकन कर सकते हैं।

आप PouchDB में एक डेटाबेस से कई / थोक दस्तावेजों को पढ़ / प्राप्त कर सकते हैं allDocs() तरीका।

वाक्य - विन्यास

निम्नलिखित का उपयोग करने का वाक्यविन्यास है db.allDocs()पाउचडीबी की विधि। यह विधि एक वैकल्पिक कॉलबैक फ़ंक्शन को स्वीकार करती है।

db.allDocs()

उदाहरण

निम्नलिखित एक डेटाबेस में सभी दस्तावेजों को प्राप्त करने का एक उदाहरण है my_database स्थानीय रूप से संग्रहीत किया जाता है, का उपयोग करते हुए db.allDocs()तरीका। यह विधि ऑब्जेक्ट के रूप में दस्तावेज़ों की सरणी को पुनः प्राप्त करती है, प्रत्येक दस्तावेज़ की सामग्री प्राप्त करने के लिए जिसे आपको कॉल करने की आवश्यकता हैdocs.rows

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Retrieving all the documents in PouchDB
db.allDocs(function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log (docs.rows);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Read_All_Document.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Read_All_Document.js

यह उन सभी दस्तावेजों को पढ़ता है जो नाम के डेटाबेस में मौजूद हैं my_databaseजिसे स्थानीय स्तर पर संग्रहीत किया जाता है। कंसोल पर निम्न संदेश प्रदर्शित होता है।

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '1-9dc57f5faa7ea90eeec22eba8bfd05f5' } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '1-9bf80afcedb9f8b5b35567292affb254' } 
    },
   { 
      id: '003',
      key: '003',
      value: { rev: '1-1204f108e41bf8baf867856d5da16c57' } 
   }
]

सामान्य तौर पर, जैसा कि उपरोक्त परिणाम में दिखाया गया है, का उपयोग करके allDocs() विधि आप केवल देख सकते हैं _id, key तथा _revप्रत्येक दस्तावेज़ के क्षेत्र। हालांकि, परिणाम में पूरे दस्तावेज़ को शामिल करने के लिए, आपको वैकल्पिक पैरामीटर बनाना होगाinclude_docs जैसा कि नीचे दिखाया गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Retrieving all the documents in PouchDB
db.allDocs({include_docs: true}, function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log (docs.rows);
   }
});

उपरोक्त कोड को निष्पादित करने से आपको निर्दिष्ट दस्तावेजों में पूर्ण दस्तावेजों की एक सूची मिलती है जैसा कि निम्नलिखित कोड में दिखाया गया है।

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '1-9dc57f5faa7ea90eeec22eba8bfd05f5' },
      doc: { 
         name: 'Ram',
         age: 23,
         Designation: 'Programmer',
         _id: '001',
         _rev: '1-9dc57f5faa7ea90eeec22eba8bfd05f5' 
      } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '1-9bf80afcedb9f8b5b35567292affb254' },
      doc: { 
         name: 'Robert',
         age: 24,
         Designation: 'Programmer',
         _id: '002',
         _rev: '1-9bf80afcedb9f8b5b35567292affb254' 
      } 
   },
   { 
      id: '003',
      key: '003',
      value: { rev: '1-1204f108e41bf8baf867856d5da16c57' },
      doc: { 
         name: 'Rahim',
         age: 25,
         Designation: 'Programmer',
         _id: '003',
         _rev: '1-1204f108e41bf8baf867856d5da16c57' 
      } 
   }
]

रिमोट डेटाबेस से एक बैच पढ़ना

आप डेटाबेस से सभी दस्तावेज़ भी प्राप्त कर सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत हैं।

डेटाबेस नाम के बजाय ऐसा करने के लिए, आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें पढ़ा जाना है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

निम्नलिखित उन सभी दस्तावेजों को पढ़ने का एक उदाहरण है जो एक डेटाबेस में मौजूद हैं my_database जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Retrieving all the documents in PouchDB
db.allDocs({include_docs: true}, function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log(docs.rows);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Read_AllDocument.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Read_AllDocument.js

यह दिए गए दस्तावेज़ की सामग्री को पढ़ता है जो नामांकित डेटाबेस में मौजूद है my_database जो CouchDB में संग्रहीत है, और नीचे दिखाए गए अनुसार कंसोल पर प्रदर्शित होता है।

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '3-552920d1ca372986fad7b996ce365f5d' },
      doc: { 
         _id: '001',
         _rev: '3-552920d1ca372986fad7b996ce365f5d',
         name: 'Raju',
         age: 23,
         designation: 'Designer' 
      } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '1-9af15cb11054ebe03a7816bf6c5e4128' },
      doc: { 
         _id: '002',
         _rev: '1-9af15cb11054ebe03a7816bf6c5e4128',
         name: 'Robert',
         age: 24,
         Designation: 'Programmer' 
      } 
   },
   { 
      id: '003',
      key: '003',
      value: { rev: '1-3033b5a78e915c52fd37325d42eb3935' },
      doc: { 
         _id: '003',
         _rev: '1-3033b5a78e915c52fd37325d42eb3935',
         name: 'Rahim',
         age: 25,
         Designation: 'Programmer' 
      } 
   } 
]

आप एक बार में PouchDB में दस्तावेजों की एक सरणी अद्यतन कर सकते हैं bulkDocs()तरीका। ऐसा करने के लिए आपको दस्तावेज़ों की एक सरणी बनाने की आवश्यकता होती है जहाँ, प्रत्येक दस्तावेज़ में होता है_id, _rev और जिन मूल्यों को अद्यतन किया जाना है।

मान लीजिए नाम का डेटाबेस my_database PouchDB में स्थानीय रूप से संग्रहीत किया जाता है जिसमें 3 दस्तावेज़ होते हैं जैसे कि doc1, doc2, doc3 में निम्नलिखित सामग्री होती है।

doc1 = {_id: '001', name: 'Ram', age: 23, Designation: 'Programmer'}
doc2 = {_id: '002', name: 'Robert', age: 24, Designation: 'Programmer'}
doc3 = {_id: '003', name: 'Rahim', age: 25, Designation: 'Programmer'}

मान लीजिए कि हमें सभी 3 दस्तावेजों में 2 साल तक उम्र का मान बढ़ाना है। ऐसा होने के लिए, पहले आपको इसे प्राप्त करने की आवश्यकता है_revमान। इसलिए, निम्न कोड का उपयोग करके इन दस्तावेजों की सामग्री प्राप्त करें।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Retrieving all the documents in PouchDB
db.allDocs({include_docs: true},function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log(docs.rows);
   }
});

उपरोक्त कोड को इस प्रकार सेव करें bulk_fetch.js। निष्पादित करने पर, उपरोक्त कार्यक्रम आपको डेटाबेस में दस्तावेजों के _id और _rev मान देता है जैसा कि नीचे दिखाया गया है।

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '1-1604b0c3ff69dc1e261265fd60808404' } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '1-b5e49db7e984841bf12a13e3ee548125' } 
   },
   { 
      id: '003',
      key: '003',
      value: { rev: '1-a7b342786ecc707aa91f3b321a177b51' } 
   } 
]

अब, आप उनके संबंधित दस्तावेजों का उपयोग करके अपडेट कर सकते हैं _id तथा _rev मूल्यों को नीचे दिखाया गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_databas');

//Preparing the document
docs = [{_id : '001', _rev: '1-1604b0c3ff69dc1e261265fd60808404', age : 25, },
      {_id : '002', _rev: '1-b5e49db7e984841bf12a13e3ee548125', age : 26, },
      {_id : '003', _rev: '1-a7b342786ecc707aa91f3b321a177b51', age : 27 }]

//Updating the documents in bulk
db.bulkDocs(docs, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Documents Updated Successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Update_All_Document.js। कमांड प्रॉम्प्ट खोलें और नीचे दिखाए अनुसार नोड का उपयोग करके जावास्क्रिप्ट फ़ाइल को निष्पादित करें।

C:\PouchDB_Examples >node Update_All_Document.js

यह उन सभी दस्तावेजों को अपडेट करता है जो नामांकित डेटाबेस में मौजूद हैं my_database जो स्थानीय रूप से संग्रहीत है, निम्न संदेश प्रदर्शित करता है।

Documents Updated Successfully

अब, यदि आप निष्पादित करते हैं bulk_fetch.js जोड़कर कार्यक्रम {include_docs: true} एक पैरामीटर के रूप में allDocs() फ़ंक्शन, कॉलबैक से पहले, फिर, आप अपडेट किए गए दस्तावेजों के मूल्यों को देख सकते हैं, जैसा कि नीचे दिखाया गया है।

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '2-77f3a9974dd578d12f3f2a33aae64c8d' },
      doc: { 
         age: 25,
         _id: '001',
         _rev: '2-77f3a9974dd578d12f3f2a33aae64c8d' 
      } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '2-43966007568ce9567c96422195fcfa0d' },
      doc: { 
         age: 26,
         _id: '002',
         _rev: '2-43966007568ce9567c96422195fcfa0d' 
      } 
   },
   { 
      id: '003',
      key: '003',
      value: { rev: '2-6c5349652527f4f39583ff14f23cd677' },
      doc: { 
         age: 27,
         _id: '003',
         _rev: '2-6c5349652527f4f39583ff14f23cd677' 
      } 
   } 
]

रिमोट डेटाबेस से बैच अपडेट करना

आप डेटाबेस से सभी दस्तावेज़ों को अपडेट कर सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत हैं।

ऐसा करने के लिए, डेटाबेस नाम के बजाय, आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें पढ़ा जाना है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

और मान लें कि हम नामित डेटाबेस का चयन करते हैं my_database, आप देख सकते हैं कि इसमें 3 दस्तावेज़ शामिल हैं जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

अब, निम्न कोड का उपयोग करके इन दस्तावेजों की सामग्री प्राप्त करें।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Retrieving all the documents in PouchDB
db.allDocs({include_docs: true}, function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log(docs.rows);
   }
});

उपरोक्त कोड को इस प्रकार सेव करें remote_bulk_fetch.js। निष्पादित करने पर, उपरोक्त कार्यक्रम आपको डेटाबेस में सभी दस्तावेजों की सामग्री देता है जैसा कि नीचे दिखाया गया है।

[ 
   { 
      id: '001', 
      key: '001', 
      value: { rev: '3-552920d1ca372986fad7b996ce365f5d' }, 
      doc: { 
         _id: '001', 
         _rev: '3-552920d1ca372986fad7b996ce365f5d', 
         name: 'Raju', 
         age: 23, 
         designation: 'Designer' 
      } 
   },
   { 
      id: '002', 
      key: '002', 
      value: { rev: '1-9af15cb11054ebe03a7816bf6c5e4128' }, 
      doc: { 
         _id: '002', 
         _rev: '1-9af15cb11054ebe03a7816bf6c5e4128', 
         name: 'Robert', 
         age: 24, 
         Designation: 'Programmer' 
      } 
   }, 
   { 
      id: '003', 
      key: '003', 
      value: { rev: '1-3033b5a78e915c52fd37325d42eb3935' }, 
      doc: { 
         _id: '003',
         _rev: '1-3033b5a78e915c52fd37325d42eb3935',
         name: 'Rahim', 
         age: 25, 
         Designation: 'Programmer' 
      } 
   } 
]

निम्नलिखित उन सभी दस्तावेजों को अद्यतन करने का एक उदाहरण है जो एक डेटाबेस में मौजूद हैं my_database जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package 
var PouchDB = require('PouchDB');

//Creating the database object 
var db = new PouchDB('http://localhost:5984/my_database'); 

//Preparing the document 
docs = [{_id : '001', _rev: '3-552920d1ca372986fad7b996ce365f5d', age : 24, }, 
      {_id : '002', _rev: '1-9af15cb11054ebe03a7816bf6c5e4128', age : 26, }, 
      {_id : '003', _rev: '1-3033b5a78e915c52fd37325d42eb3935', age : 27}]

//Inserting Document 
db.bulkDocs(docs, function(err, response) { 
   if (err) { 
      return console.log(err); 
   } else { 
      console.log(+"Documents Updated Successfully"); 
   } 
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Update_Document.js। कमांड प्रॉम्प्ट खोलें और नीचे दिखाए अनुसार नोड का उपयोग करके जावास्क्रिप्ट फ़ाइल को निष्पादित करें।

C:\PouchDB_Examples >node Remote_Update_Document.js

यह दिए गए डेटाबेस में मौजूद सभी दिए गए दस्तावेज़ की सामग्री को अद्यतन करता है my_database जो CouchDB में संग्रहीत है, और निम्न संदेश प्रदर्शित करता है।

Documents Updated Successfully

अब, यदि आप निष्पादित करते हैं remote_bulk_fetch.js कार्यक्रम आप अद्यतन दस्तावेजों के मूल्यों को देख सकते हैं, जैसा कि नीचे दिखाया गया है।

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '4-6bc8d9c7a60fed2ed1667ec0740c1f39' },
      doc: { 
         _id: '001',
         _rev: '4-6bc8d9c7a60fed2ed1667ec0740c1f39',
         age: 25 
      } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '2-1aa24ce77d96bb9d2a0675cdf1e113e0' },
      doc: { 
         _id: '002',
         _rev: '2-1aa24ce77d96bb9d2a0675cdf1e113e0',
         age: 26 
      } 
   },
   { 
      id: '003',
      key: '003',
      value: { rev: '2-fa113149ba618eda77f73072974a2bc1' },
      doc: { 
         _id: '003',
         _rev: '2-fa113149ba618eda77f73072974a2bc1',
         age: 27 
      } 
   } 
]

आप एक बार में पाउचडीबी में दस्तावेजों के एक सरणी को हटा सकते हैं bulkDocs()तरीका। ऐसा करने के लिए आपको उन दस्तावेज़ों की एक सारणी बनाने की आवश्यकता होती है, जिन्हें हटा दिया जाना चाहिए जहाँ, प्रत्येक दस्तावेज़ में होना चाहिए_id तथा _rev। इनके अलावा आपको एक और की-वैल्यू पेयर जोड़ना होगा_deleted: true

मान लीजिए नाम का डेटाबेस my_database PouchDB में स्थानीय रूप से संग्रहीत किया जाता है जिसमें 3 दस्तावेज़ होते हैं जैसे कि doc1, doc2, doc3 में निम्नलिखित सामग्री होती है।

doc1 = {_id: '001', name: 'Ram', age: 23, Designation: 'Programmer'}
doc2 = {_id: '002', name: 'Robert', age: 24, Designation: 'Programmer'}
doc3 = {_id: '003', name: 'Rahim', age: 25, Designation: 'Programmer'}

और कहते हैं, हमें तीनों दस्तावेजों को हटाना होगा। फिर, सबसे पहले आपको उनकी आवश्यकता है_revमान। इसलिए, निम्न कोड का उपयोग करके इन दस्तावेजों की सामग्री प्राप्त करें।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Retrieving all the documents in PouchDB
db.allDocs({include_docs: true},function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log(docs.rows);
   }
});

उपरोक्त कोड को इस प्रकार सेव करें bulk_fetch.js। उपरोक्त कार्यक्रम को निष्पादित करने से आपको डेटाबेस में दस्तावेजों के _id और _rev मान मिलते हैं जैसा कि नीचे दिखाया गया है।

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '1-1604b0c3ff69dc1e261265fd60808404' } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '1-b5e49db7e984841bf12a13e3ee548125' } 
   },
   { 
      id: '003',
      key: '003',
      value: { rev: '1-a7b342786ecc707aa91f3b321a177b51' } 
   } 
]

अब, आप उनके संबंधित दस्तावेजों का उपयोग करके हटा सकते हैं _id तथा _rev मूल्यों को नीचे दिखाया गया है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Preparing the document
docs = [{_id : '001', _rev: '2-77f3a9974dd578d12f3f2a33aae64c8d', _deleted : true },
      {_id : '002', _rev: '2-43966007568ce9567c96422195fcfa0d', _deleted : true }, 
      {_id : '003', _rev: '2-6c5349652527f4f39583ff14f23cd677',_deleted : true }]

//Deleting Documents
db.bulkDocs(docs, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log(response+"Documents deleted Successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Delete_All_Document.js। कमांड प्रॉम्प्ट खोलें और नीचे दिखाए अनुसार नोड का उपयोग करके जावास्क्रिप्ट फ़ाइल को निष्पादित करें।

C:\PouchDB_Examples >node Delete_All_Document.js

यह उन सभी दस्तावेज़ों को हटा देता है जो नामित डेटाबेस में मौजूद हैं my_database जो स्थानीय रूप से संग्रहीत है, निम्न संदेश प्रदर्शित करता है।

Documents Deleted Successfully

अब, यदि आप निष्पादित करते हैं bulk_fetch.js प्रोग्राम, आप कंसोल पर एक खाली ब्रेस का निरीक्षण कर सकते हैं जो यह दर्शाता है कि डेटाबेस खाली है, जैसा कि नीचे दिखाया गया है।

[]

दूरस्थ डेटाबेस से बैच हटाना

आप डेटाबेस से सभी दस्तावेज़ों को अपडेट कर सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत हैं।

ऐसा करने के लिए, डेटाबेस नाम के बजाय, आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें पढ़ा जाना है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

यदि हम नामित डेटाबेस का चयन करते हैं my_database, आप देख सकते हैं कि इसमें 3 दस्तावेज़ शामिल हैं जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

निम्नलिखित उन सभी दस्तावेज़ों को हटाने का एक उदाहरण है जो नाम के डेटाबेस में मौजूद हैं my_database जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Preparing the document
docs = [{_id : '001', _rev: '4-6bc8d9c7a60fed2ed1667ec0740c1f39', _deleted : true },
      {_id : '002', _rev: '2-1aa24ce77d96bb9d2a0675cdf1e113e0', _deleted : true },
      {_id : '003', _rev: '2-fa113149ba618eda77f73072974a2bc1',_deleted : true }]

//Deleting Documents
db.bulkDocs(docs, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log("Documents deleted Successfully");
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_delete_AllDocuments.js। कमांड प्रॉम्प्ट खोलें और नीचे दिखाए अनुसार नोड का उपयोग करके जावास्क्रिप्ट फ़ाइल को निष्पादित करें।

C:\PouchDB_Examples >node Remote_Delete_AllDocuments.js

यह दिए गए डेटाबेस में मौजूद सभी दिए गए दस्तावेज़ की सामग्री को हटा देता है my_database जो CouchDB में संग्रहीत है, और निम्न संदेश प्रदर्शित करता है।

Documents Deleted Successfully

आप बाइनरी ऑब्जेक्ट को किसी दस्तावेज़ का उपयोग करके संलग्न कर सकते हैं putAttachment() PouchDB में विधि।

वाक्य - विन्यास

निम्नलिखित का सिंटैक्स है putAttachment()। इस विधि के लिए, हमें डॉक्यूमेंट आईडी, अटैचमेंट आईडी, MIME टाइप को अटैचमेंट के साथ पास करना होगा। यह विधि एक वैकल्पिक कॉलबैक फ़ंक्शन को भी स्वीकार करती है।

db.putAttachment( docId, attachmentId, attachment, type, [callback] );

हम बूँद या बफर ऑब्जेक्ट्स का उपयोग करके अनुलग्नक तैयार कर सकते हैं, जहां blob ब्राउज़र के साथ काम करते समय उपयोग किया जाता है और buffer के साथ काम करते समय उपयोग किया जाता है Node.jsचूंकि हम Node.js में अपने कार्यक्रमों का प्रदर्शन कर रहे हैं, इसलिए हम दस्तावेज़ तैयार करने के लिए बफर ऑब्जेक्ट का उपयोग करते हैं।

उदाहरण

निम्नलिखित एक अनुलग्नक के साथ एक दस्तावेज बनाने का एक उदाहरण है, जिसका नाम डेटाबेस है my_database का उपयोग कर PouchDB में putAttachment() तरीका।

//Requiring the package 
var PouchDB = require('PouchDB');

//Creating the database object var db = new PouchDB('my_database');

//Preparing the attachment 
var my_attachment = new Buffer(['Welcome to tutorialspoint'], {type: 'text/plain'});

//Adding attachment to a document 
db.putAttachment('001', 'att_1.txt', my_attachment, 'text/plain', function(err, res) { 
   if (err) { 
      return console.log(err); 
   } else { 
      console.log(res+"Attachment added successfully") 
   } 
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Add_Attachment.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Add_Attachment.js

यह नाम में डेटाबेस में, इसके लिए एक अनुलग्नक जोड़कर एक खाली दस्तावेज़ बनाता है my_database जो PouchDB में संग्रहीत है, और निम्न संदेश प्रदर्शित करता है।

Attachment added successfully

आप यह सत्यापित कर सकते हैं कि निम्नलिखित कोड का उपयोग करके दस्तावेज़ को पढ़कर अनुलग्नक जोड़ा गया है या नहीं।

//Requiring the package 
var PouchDB = require('PouchDB');

//Creating the database object var db = new PouchDB('my_database');

//Reading the Document 
db.get('001',{attachments: true}, function(err, doc) { 
   if (err) { 
      return console.log(err); 
   } else { 
      console.log(doc); 
   } 
});

उपरोक्त कोड को इस प्रकार सेव करें read_doc.jsऔर इसे निष्पादित करें। इस कार्यक्रम को निष्पादित करते हुए, आप दस्तावेज़ की निम्न सामग्री देख सकते हैं।

{ 
   _attachments: { 
      att_1.txt: { 
         content_type: 'text/plain',
         digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==',
         data: 'AA==' 
      } 
   },
   _id: '001',
   _rev: '1-620fd5f41d3328fcbf9ce7504338a51d' 
}

मौजूदा दस्तावेज़ में अनुलग्नक जोड़ना

मान लीजिए, नाम से एक डेटाबेस में एक दस्तावेज है my_database PouchDB id के साथ '002'। आप इसे निष्पादित करके सामग्री प्राप्त कर सकते हैंread_doc.js आईडी मान को बदलकर 002, जैसा की नीचे दिखाया गया।

{ 
   name: 'Raju',
   age: 23,
   designation: 'Designer',
   _id: '002',
   _rev: '1-05ca7b5f3f4762a9fb2d119cd34c8d40' 
}

अब, आप इसके उपयोग से इस दस्तावेज़ के प्रति लगाव जोड़ सकते हैं _rev मूल्य।

//Requiring the package 
var PouchDB = require('PouchDB');

//Creating the database object var db = new PouchDB('my_database');

//Adding attachment to existing document 
var my_attachment = new Buffer (['Welcome to tutorialspoint'], {type: 'text/plain'});

rev = '1-05ca7b5f3f4762a9fb2d119cd34c8d40'; 
db.putAttachment('002', 'att_1.txt', rev, my_attachment, 'text/plain', function(err, res) { 
   if (err) { 
      return console.log(err); 
   } else { 
      console.log (res + "Attachment added successfully") 
   } 
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Add_Attachment_to_doc.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Add_Attachment_to_doc.js

यह निम्नलिखित संदेश प्रदर्शित करने वाले निर्दिष्ट दस्तावेज़ के साथ एक लगाव जोड़ता है।

Attachment added successfully

यदि आप आईडी मान को बदलते हैं read_doc.js सेवा 002 और इसे निष्पादित करें, आपको निम्न आउटपुट मिलेगा।

{ 
   name: 'Raju',
   age: 23,
   designation: 'Designer',
   _attachments: { 
      att_1: { 
         content_type: 'text/plain',
         digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==',
         data: 'AA==' 
      } 
   },
   _id: '002',
   _rev: '2-3bb4891b954699bce28346723cc7a709' 
}

दूरस्थ दस्तावेज़ में अनुलग्नक जोड़ना

तुम भी एक डेटाबेस में मौजूदा दस्तावेज़ के लिए एक लगाव जोड़ सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत है।

ऐसा करने के लिए, डेटाबेस नाम के बजाय, आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें पढ़ा जाना है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

और अगर आप नामित डेटाबेस का चयन करते हैं my_database, आप इसकी सामग्री को नीचे दिखाए अनुसार देख सकते हैं।

निम्नलिखित दस्तावेज़ में लगाव जोड़ने का एक उदाहरण है 001 नामक डेटाबेस में संग्रहीत my_database जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('http://localhost:5984/my_database');

//Adding attachment to existing document
var my_attachment = new Buffer (['Welcome to tutorialspoint'], {type: 'text/plain'});

rev = '1-36c34fdcf29a652876219065f9681602';
db.putAttachment('001', 'att_1.txt',rev, my_attachment, 'text/plain', function(err, res) {
   if (err) {
      return console.log(err);
   } else {
      console.log (res+ "Attachment added successfully")
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Add_Attachment.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Add_Attachment.js

यह निम्नलिखित संदेश प्रदर्शित करने वाले निर्दिष्ट दस्तावेज़ के साथ एक लगाव जोड़ता है।

Attachment added successfully

अब, यदि आप दस्तावेज़ को सत्यापित करते हैं, तो आप इसमें जोड़े गए अनुलग्नक का पालन कर सकते हैं जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

आप का उपयोग करके PouchDB से लगाव प्राप्त कर सकते हैं getAttachment()तरीका। यह विधि हमेशा बूँद या बफर ऑब्जेक्ट लौटाती है।

वाक्य - विन्यास

निम्नलिखित का सिंटैक्स है getAttachment()। इस विधि के लिए, हमें दस्तावेज़ आईडी और अनुलग्नक आईडी पास करना होगा। यह विधि एक वैकल्पिक कॉलबैक फ़ंक्शन को भी स्वीकार करती है।

db.getAttachment( docId, attachmentId, [callback] );

उदाहरण

निम्नलिखित का उपयोग करके, PouchDB में संग्रहीत दस्तावेज़ के अनुलग्नक को पुनः प्राप्त करने का एक उदाहरण है getAttachment()तरीका। इस कोड का उपयोग करते हुए, हम अनुलग्नक को पुनः प्राप्त करने का प्रयास कर रहे हैंatt_1.txt दस्तावेज़ से 001

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Retrieving an attachment from a document
db.getAttachment('001', 'att_1.txt', function(err, blob_buffer) {
   if (err) {
      return console.log(err);
   } else {
      console.log(blob_buffer);
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Retrieve_Attachment.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Retrieve_Attachment.js

यह दस्तावेज़ के अनुलग्नक को पुनः प्राप्त करता है और कंसोल पर प्रदर्शित होता है जैसा कि नीचे दिखाया गया है।

<Buffer 00>

दूरस्थ दस्तावेज़ से अनुलग्नक पुनर्प्राप्त करना

आप डेटाबेस में मौजूद दस्तावेज़ के अनुलग्नक को भी पुनः प्राप्त कर सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत होता है।

ऐसा करने के लिए, डेटाबेस नाम के बजाय, आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें पढ़ा जाना है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

यदि आप नामित डेटाबेस का चयन करते हैं my_database, आप इसकी सामग्री को नीचे दिखाए अनुसार देख सकते हैं।

मान लीजिए, इस दस्तावेज़ में एक लगाव है जैसा कि नीचे दिखाया गया है।

निम्नलिखित दस्तावेज़ का लगाव प्राप्त करने का एक उदाहरण है 001 नाम के डेटाबेस में मौजूद है my_database, जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package 
var PouchDB = require('PouchDB');

//Creating the database object 
var db = new PouchDB('http://localhost:5984/my_database');

//Retrieving an attachment from a document 
db.getAttachment('001', 'att_1.txt', function(err, blob_buffer) { 
   if (err) { 
      return console.log(err); 
   } else { 
      console.log(blob_buffer); 
   } 
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Retrieve_Attachment.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Retrieve_Attachment.js

यह दस्तावेज़ के अनुलग्नक को पुनः प्राप्त करता है और इसे कंसोल पर प्रदर्शित करता है जैसा कि नीचे दिखाया गया है।

<Buffer 00>

आप का उपयोग करके PouchDB से लगाव को हटा सकते हैं removeAttachment() तरीका।

वाक्य - विन्यास

निम्नलिखित का सिंटैक्स है removeAttachment()तरीका। इस पद्धति के लिए, हमें दस्तावेज़ आईडी, अटैचमेंट आईडी और _rev मान पास करना होगा। यह विधि एक वैकल्पिक कॉलबैक फ़ंक्शन को भी स्वीकार करती है।

db.removeAttachment ( docId, attachmentId, rev, [callback] );

उदाहरण

मान लीजिए कि आईडी के साथ पाउचडीबी में एक दस्तावेज है 001, जिसमें आईडी, नाम, आयु, एक कर्मचारी के पदनाम के साथ एक संलग्नक शामिल है जैसा कि नीचे दिखाया गया है।

{ 
   name: 'Raju',
   age: 23,
   designation: 'Designer',
   _attachments: { 
      'att_1.txt': { 
         content_type: 'text/plain',
         digest: 'md5-k7iFrf4NoInN9jSQT9WfcQ==',
         data: 'AA==' 
      } 
   },
   _id: '001',
   _rev: '2-cdec6c9f45ddbee7d456945654742d43' 
}

निम्नलिखित इस दस्तावेज़ के लगाव को हटाने का एक उदाहरण है 001 का उपयोग कर, PouchDB में संग्रहीत removeAttachment() तरीका।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my');
db.removeAttachment('001', 'att_1.txt', '2-cdec6c9f45ddbee7d456945654742d43', 
   function(err, res) {
   if (err) {
      return console.log(err);
   } else {
      console.log(res+"Attachment Deleted successfully")
   }
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remove_Attachment.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remove_Attachment.js

यह दस्तावेज़ के अनुलग्नक को हटाता है और नीचे दिखाए गए अनुसार कंसोल पर एक संदेश प्रदर्शित करता है।

Attachment deleted successfully

हटाने के बाद, आप निम्नलिखित कोड को निष्पादित करके दस्तावेज़ की सामग्री को सत्यापित कर सकते हैं।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_d');

//Reading the Document
db.get('001',{attachments: true}, function(err, doc) {
   if (err) {
      return console.log(err);
   } else {
      console.log(doc);
   }
});

इस कोड को इस प्रकार सेव करें read.jsऔर इसे निष्पादित करें। निष्पादित करने पर, आपको अनुलग्नक को हटाने के बाद दस्तावेज़ की सामग्री मिल जाएगी, जैसा कि नीचे दिखाया गया है।

{ 
   name: 'Raju',
   age: 23,
   designation: 'Designer',
   _id: '001',
   _rev: '3-da775487a6ed0495f2e49c543384f8e8' 
}

दूरस्थ दस्तावेज़ से अनुलग्नक निकालना

आप डेटाबेस में मौजूदा दस्तावेज़ के अनुलग्नक को हटा सकते हैं जो सर्वर (CouchDB) पर दूरस्थ रूप से संग्रहीत होता है।

ऐसा करने के लिए, डेटाबेस नाम के बजाय, आपको CouchDB में डेटाबेस के लिए पथ को पारित करने की आवश्यकता है, जिसमें वह दस्तावेज़ है जिसमें पढ़ा जाना है।

उदाहरण

मान लीजिए कि नाम का एक डेटाबेस है my_databaseCouchDB सर्वर में। फिर, यदि आप URL का उपयोग करके CouchDB में डेटाबेस की सूची को सत्यापित करते हैंhttp://127.0.0.1:5984/_utils/index.html आपको निम्न स्क्रीनशॉट मिलेगा।

और अगर आप नामित डेटाबेस का चयन करते हैं my_database, आप इसकी सामग्री को नीचे दिखाए अनुसार देख सकते हैं।

मान लीजिए कि इस दस्तावेज़ में एक लगाव है जैसा कि नीचे दिखाया गया है।

निम्नलिखित दस्तावेज़ के उपरोक्त अनुलग्नक को हटाने का एक उदाहरण है 001 नाम के डेटाबेस में मौजूद है my_database जो CouchDB सर्वर में संग्रहीत है।

//Requiring the package 
var PouchDB = require('PouchDB');

//Creating the database object 
var db = new PouchDB('http://localhost:5984/my_database');

db.removeAttachment('001', 'att_1.txt', '2-049f1c4ffa54576ec0947b65e34de423', 
   function(err, res) { 
   if (err) { 
      return console.log(err); 
   } else { 
      console.log(res+"Attachment Deleted successfully") 
   } 
});

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Remote_Delete_Attachment.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Remote_Delete_Attachment.js

यह मौजूदा अनुलग्नक को निकालता है और निम्न संदेश प्रदर्शित करता है।

Attachment Deleted successfully

यदि आप फिर से दस्तावेज़ पर जाते हैं, तो आप देख सकते हैं कि अनुलग्नक को हटा दिया गया था जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

PouchDB की सबसे महत्वपूर्ण विशेषताओं में से एक प्रतिकृति है, यानी आप एक डेटाबेस की एक प्रति बना सकते हैं। आप या तो एक PouchDB उदाहरण स्थानीय रूप से संग्रहीत या CouchDB उदाहरण दूरस्थ रूप से संग्रहीत कर सकते हैं।

वाक्य - विन्यास

निम्नलिखित PouchDB में एक डेटाबेस की नकल का वाक्यविन्यास है। यहाँ, की एक प्रतिsource databaseलक्ष्य है। इस पद्धति के लिए, आप सीधे स्ट्रिंग प्रारूप में स्रोत और गंतव्य डेटाबेस के स्थान को पास कर सकते हैं, या आप उनका प्रतिनिधित्व करने वाली वस्तुओं को पास कर सकते हैं।

PouchDB.replicate(source, target, [options])

स्रोत और लक्ष्य दोनों ही PouchDB उदाहरण या CouchDB उदाहरण हो सकते हैं।

CDBDB में लोकलडीबी की पुनरावृत्ति

मान लीजिए कि नाम के साथ एक डेटाबेस है sample_database PouchDB में, और इसमें 3 दस्तावेज़ doc1, doc2, और doc3 शामिल हैं, जिनकी सामग्री नीचे दी गई है।

doc1 = {_id: '001', name: 'Ram', age: 23, Designation: 'Programmer'} 
doc2 = {_id: '002', name: 'Robert', age: 24, Designation: 'Programmer'} 
doc3 = {_id: '003', name: 'Rahim', age: 25, Designation: 'Programmer'}

निम्नलिखित एक उदाहरण है जो डेटाबेस नाम की एक प्रतिलिपि बनाता है sample_database यह CouchDB में स्थानीय रूप से संग्रहीत है।

//Requiring the package 
var PouchDB = require('PouchDB');

var localdb = 'sample_database';

//Creating remote database object 
var remotedb = 'http://localhost:5984/sample_database';

//Replicating a local database to Remote 
PouchDB.replicate(localDB, remoteDB); 
console.log ("Database replicated successfully");

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Replication_example.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Replication_example.js

यह CouchDB उदाहरण में नमूना_डेटाबेस नामक डेटाबेस की एक प्रतिलिपि बनाता है और नीचे दिखाए गए अनुसार कंसोल पर एक संदेश प्रदर्शित करता है।

Database replicated successfully

आप निम्न लिंक पर क्लिक करके यह सत्यापित कर सकते हैं कि डेटाबेस आपके CouchDB उदाहरण में दोहराया गया है या नहीं http://127.0.0.1:5984/_utils/index.html

क्लिक करने पर, आप अपने CouchDB में डेटाबेस की सूची देख सकते हैं। आप डेटाबेस की एक प्रति भी देख सकते हैंsample_database यहाँ बनाया गया है।

यदि आप प्रतिरूपित डेटाबेस का चयन करते हैं, तो आप नीचे दिखाए अनुसार इसकी सामग्री देख सकते हैं।

PouchDB के लिए CouchDB की पुनरावृत्ति

मान लीजिए कि नाम के साथ एक डेटाबेस है Remote_Database CouchDB में और इसमें 3 दस्तावेज़ शामिल हैं, doc1, doc2, और doc3, जिसमें नीचे दी गई सामग्री है।

doc1 = {_id: '001', name: 'Geeta', age: 25, Designation: 'Programmer'}
doc2 = {_id: '002', name: 'Zara Ali', age: 24, Designation: 'Manager'}
doc3 = {_id: '003', name: 'Mary', age: 23, Designation: 'Admin'}

निम्नलिखित एक उदाहरण है जो डेटाबेस नाम की एक प्रतिलिपि बनाता है Remote_Database यह CouchDB में स्थानीय भंडारण में संग्रहीत किया जाता है।

//Requiring the package
var PouchDB = require('PouchDB');

var localdb = 'sample_database';

var remotedb = 'http://localhost:5984/sample_database1';

//Replicating a local database to Remote
PouchDB.replicate(remotedb, localdb);
console.log("Database replicated successfully");

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Replication_example2.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Replication_example2.js

यह नाम के डेटाबेस की एक प्रतिलिपि बनाता है remote_database PouchDB उदाहरण में और नीचे दिखाए गए अनुसार कंसोल पर एक संदेश प्रदर्शित करता है।

Database replicated successfully

आप यह सत्यापित कर सकते हैं कि डेटाबेस निम्नलिखित कोड को निष्पादित करके आपके पाउच उदाहरण में दोहराया गया है या नहीं।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('remote_database');

//Retrieving all the documents in PouchDB
db.allDocs({include_docs: true, attachments: true}, function(err, docs) {
   if (err) {
      return console.log(err);
   } else {
      console.log(docs.rows);
   }
});

यदि डेटाबेस उपरोक्त कोड को निष्पादित करने पर दोहराया जाता है, तो आपको नीचे दिखाए गए अनुसार डेटाबेस की सामग्री मिलेगी।

[ 
   { 
      id: '001', 
      key: '001', 
      value: { rev: '1-23cf3767e32a682c247053b16caecedb' }, 
      doc: { 
         name: 'Geeta', 
         age: 25, 
         Designation: 'Programmer', 
         _id: '001',
         _rev: '1-23cf3767e32a682c247053b16caecedb' 
      } 
   }, 
   { 
      id: '002', 
      key: '002', 
      value: { rev: '1-d5bcfafbd4d4fae92fd7fc4fdcaa3a79' }, 
      doc: { 
         name: 'Zara Ali', 
         age: 24, 
         Designation: 'Manager', 
         _id: '002',
         _rev: '1-d5bcfafbd4d4fae92fd7fc4fdcaa3a79' 
      } 
   }, 
   { 
      id: '003', 
      key: '003', 
      value: { rev: '1-c4cce025dbd30d21e40882d41842d5a4' }, 
      doc: { 
         name: 'Mary', 
         age: 23, 
         Designation: 'Admin', 
         _id: '003', 
         _rev: '1-c4cce025dbd30d21e40882d41842d5a4' 
      } 
   } 
]

आप PouchDB में स्थानीय रूप से संग्रहीत डेटाबेस को उन लोगों के साथ सिंक्रनाइज़ कर सकते हैं जो CouchDB में संग्रहीत हैं। पिछले अध्याय में, हमने देखा है कि PouchDB का उपयोग करके डेटाबेस को कैसे दोहराया जाए। वहां हमने विधि का उपयोग किया हैPouchDB.replicate(source, destination)

इसके अतिरिक्त, हम स्थानीय डेटाबेस से दूरस्थ डेटाबेस तक और दूरस्थ डेटाबेस से स्थानीय डेटाबेस का उपयोग करके भी डेटा को दोहरा सकते हैं। replicate.to() तथा replicate.from() नीचे दिए गए तरीके।

//Replicating data from local database to remote database 
localDB.replicate.to(remoteDB);

//Replicating data from remote database to local database 
localDB.replicate.from(remoteDB);

कहाँ पे, localDB PouchDB में स्थानीय रूप से संग्रहीत डेटाबेस की एक वस्तु है और remoteDB एक डेटाबेस का एक ऑब्जेक्ट है जो CouchDB में संग्रहीत है।

उदाहरण

मान लीजिए कि नाम के साथ एक डेटाबेस है local_database PouchDB में, और इसमें 3 दस्तावेज़ शामिल हैं, doc1, doc2, और doc3, जिसमें नीचे दी गई सामग्री है।

doc1 = {_id: '003', name: 'Ram', age: 26, Designation: 'Programmer'} 
doc2 = {_id: '004', name: 'Robert', age: 27, Designation: 'Programmer'} 
doc3 = {_id: '005', name: 'Rahim', age: 28, Designation: 'Programmer'}

और नाम के साथ एक डेटाबेस है Remote_Database CouchDB में और इसमें 2 दस्तावेज़ doc1, doc2, नीचे दिखाए अनुसार सामग्री है।

doc1 = {_id: '001', name: 'Geeta', age: 25, Designation: 'Programmer'} 
doc2 = {_id: '002', name: 'Zara Ali', age: 24, Designation: 'Manager'}

निम्नलिखित इन दो डेटाबेस को सिंक्रनाइज़ करने का एक उदाहरण है, जहां एक का उपयोग करके PouchDB में संग्रहीत किया जाता है और दूसरे को CouchDB में संग्रहीत किया जाता है, replicate.to() तथा replicate.from() तरीकों।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating local database object
var localDB = new PouchDB('local_database');

//Creating remote database object
var remoteDB = new PouchDB('http://localhost:5984/remote_database');

//Synchronising both databases
localDB.replicate.to(remoteDB);
remoteDB.replicate.from(localDB);
console.log("Databases synchronized successfully");

नाम के साथ फ़ाइल में उपरोक्त कोड सहेजें Synchronising_databases.js। कमांड प्रॉम्प्ट खोलें और जावास्क्रिप्ट फ़ाइल का उपयोग करके निष्पादित करेंnode जैसा की नीचे दिखाया गया।

C:\PouchDB_Examples >node Synchronising_databases.js

यह दो डेटाबेस RemoteDB और localDB को सिंक्रनाइज़ करता है, और कंसोल पर एक संदेश दिखाता है जैसा कि नीचे दिखाया गया है।

Databases synchronized successfully.

सिंक्रनाइज़ करने के बाद दो डेटाबेस पर जाएँ http://127.0.0.1:5984/_utils/index.html और का चयन करें remote_database। आप देख सकते हैं कि स्थानीय डेटाबेस (003, 004, 005) के दस्तावेजों को इस डेटाबेस में कॉपी किया गया था जैसा कि नीचे दिखाया गया है।

उसी तरह, यदि आप सामग्री प्राप्त करते हैं local_database PouchDB में संग्रहीत आप देख सकते हैं कि CouchDB में संग्रहीत डेटाबेस के दस्तावेज़ यहाँ कॉपी किए गए थे।

[ 
   { 
      id: '001',
      key: '001',
      value: { rev: '1-23cf3767e32a682c247053b16caecedb' },
      doc: { 
         name: 'Geeta',
         age: 25,
         Designation: 'Programmer',
         _id: '001',
         _rev: '1-23cf3767e32a682c247053b16caecedb' 
      } 
   },
   { 
      id: '002',
      key: '002',
      value: { rev: '1-d5bcfafbd4d4fae92fd7fc4fdcaa3a79' },
      doc: { 
         name: 'Zara Ali',
         age: 24,
         Designation: 'Manager',
         _id: '002',
         _rev: '1-d5bcfafbd4d4fae92fd7fc4fdcaa3a79' 
      } 
   },
   { 
      id: '003',
      key: '003',
      value: { rev: '1-bf4619471ac346fdde46cfa8fbf3587f' },
      doc: { 
         name: 'Ram',
         age: 26,
         Designation: 'Programmer',
         _id: '003',
         _rev: '1-bf4619471ac346fdde46cfa8fbf3587f' 
      } 
   },
   { 
      id: '004',
      key: '004',
      value: { rev: '1-29b8f803958c994e3eb37912a45d869c' },
      doc: { 
         name: 'Robert',
         age: 27,
         Designation: 'Programmer',
         _id: '004',
         _rev: '1-29b8f803958c994e3eb37912a45d869c' 
      } 
   },
   { 
      id: '005',
      key: '005',
      value: { rev: '1-0eb89f71998ffa8430a640fdb081abd2' },
      doc: { 
         name: 'Rahim',
         age: 28,
         Designation: 'Programmer',
         _id: '005',
         _rev: '1-0eb89f71998ffa8430a640fdb081abd2' 
      } 
   } 
]

आप उपरोक्त प्रोग्राम का उपयोग करके फिर से लिख सकते हैं sync() दो विधियों के बजाय PouchDB द्वारा प्रदान की गई विधि replicate.to() तथा replicate.from() जैसा की नीचे दिखाया गया।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating local database object
var localDB = new PouchDB('local');

//Creating remote database object
var remoteDB = new PouchDB('http://localhost:5984/remote_database');

//Synchronising Remote and local databases
localDB.sync(remoteDB, function(err, response) {
   if (err) {
      return console.log(err);
   } else {
      console.log(response);
   }
});

उपरोक्त कार्यक्रम को निष्पादित करने पर, यह निम्नलिखित संदेश प्रदर्शित करने वाले दो डेटाबेस को सिंक्रनाइज़ करता है।

{ 
   push: { 
      ok: true,
      start_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time),
      docs_read: 6,
      docs_written: 6,
      doc_write_failures: 0,
      errors: [],
      last_seq: 10,
      status: 'complete',
      end_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time) 
   },
   pull: { 
      ok: true,
      start_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time),
      docs_read: 0,
      docs_written: 0,
      doc_write_failures: 0,
      errors: [],
      last_seq: 2,
      status: 'complete',
      end_time: Fri Mar 25 2016 15:54:37 GMT+0530 (India Standard Time) 
   } 
}

इस अध्याय में, हम PouchDB से बल्क डेटा की तरह अवधारणाओं, संघनन और पुनर्प्राप्ति पर चर्चा करेंगे।

संघनन

आप अप्रयुक्त डेटा का उपयोग करके डेटाबेस के आकार को कम कर सकते हैं compact()तरीका। आप इस विधि का उपयोग करके स्थानीय डेटाबेस के साथ-साथ दूरस्थ डेटाबेस को भी कॉम्पैक्ट कर सकते हैं।

निम्नलिखित उदाहरण के उपयोग को प्रदर्शित करता है compact() PouchDB में विधि।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('sample_database');

db.compact(function (err, result) {
   if (err) {
      return console.log(err);
   } else {
      console.log(result);
   }
});

बल्कगेट विधि

आप का उपयोग कर थोक में दस्तावेजों का एक सेट पुनः प्राप्त कर सकते हैं bulkGet()तरीका। इस विधि के लिए, आपको आईडी और _rev के सेट को पास करना होगा।

निम्नलिखित उदाहरण के उपयोग को प्रदर्शित करता है bulkGet() PouchDB में विधि।

//Requiring the package
var PouchDB = require('PouchDB');

//Creating the database object
var db = new PouchDB('my_database');

//Preparing documents
//Inserting Document
db.bulkGet({docs: [
   { id: "001", rev: "1-5dc593eda0e215c806677df1d12d5c47"},
   { id: "002", rev: "1-2bfad8a9e66d2679b99c0cab24bd9cc8"},
   { id: "003", rev: "1-7cff4a5da1f97b077a909ff67bd5b047"} ]}, function(err, result) {
   if (err) {
      return console.log(err);
   } else {
      console.log(result);
   }
});