monadbjs

0.1.6 • Public • Published

MonadbJS

Codacy Badge Build Status npm version

Fully functional database interface for JS.


Find full documentation here at MANUAL.md on Github


Installation

Via npm:

$ npm install monadbjs

Interface

Running sequential database operations more like a fluent interface sequence.

var M  = require('monadbjs');
var db = new M('mongo', 'localhost', 27017, 'db1', 'collection1').start();

db.insert({name: 'Javi', title: 'MD' })
  .insert({name: 'Craig', title: 'N/A'})
  .set({}, {'$set': {'hometown': 'Wellington'}})
  .loadAll()
  .do((ns) => doSomething(ns))
  .insert({name: 'Kevin', 'title': 'Architect', 'hometown': 'Sydney'})
  .count({'hometown': 'Wellington'})
  .do((n) => console.log(n, ' people live in Wellington'))
  .deleteAll()

Release the connection after use

db.release()

Spawn multiple connections

Each time you call .start(), the interface creates a new connection.

var db = new M('mongo', 'localhost', 27017, 'db1', 'collection1')
let conn1 = db.connect();
let conn2 = db.connect();

// And close all connections with
db.release();

Usage scenarios

Load the records given the query condition

db.load({id: 150001000})
  .do((rec) => f(rec))

Insert records then trigger another Promise

var records = [
  {a: 100, b: 200},
  {a: 100, b: null},
  {a: 200, b: null},
  {a: 300, b: 200}
];
db.insertMany(records)
  .countAll()
  .do((num) => console.log(num))
  .then(anotherPromise); // Trigger next promise as long as we finish

Update / Delete

db.update({g: 100}, {'$set': {g: 150}})
  .count({g: 100})
  .do((n) => console.log(`${n} records left`))
  .delete({g: null})
  .delete({g: 500})
  .countAll()

Aggregation

let keys = ['team','player']
let by = {goals: {'$sum': 1}}
let sort = {'goals': -1}
let prefilter = {'team': {'$ne': '$against'}}
db.agg(keys, by, sort, prefilter)
  .do((res) => console.log(res))

Iterate through records

db.forEach({foo: {'$gt': 0}}, (rec) => {
  console.log(rec);
  doSomething(rec);
})

Map records and wrap into a new Promise

db.insertMany(myRecords)
  .map({}, (n) => n.name)
  .then((ns) => ns.forEach((n) => console.log(n))) // New promise

Handle internal error

db.update({}, {'$set': {a: 100, b: 200}}) // Operation which may break
  .onFailure((e) => {
    console.error(`Exception raised ${e}`);
  })

Licence

MIT

Package Sidebar

Install

npm i monadbjs

Weekly Downloads

1

Version

0.1.6

License

MIT

Unpacked Size

26.5 kB

Total Files

9

Last publish

Collaborators

  • pataoengineer