loopback-datasource-juggler/docs/jugglingdb.md

3.8 KiB

JugglingDB(3) - cross-database ORM for nodejs and browser

DESCRIPTION

JugglingDB is a cross-db ORM for nodejs, providing common interface to access most popular database formats. Currently supported db formats are: mysql, sqlite3, postgres, couchdb, mongodb, redis, neo4j and in-memory-storage.

JugglingDB also works on client-side (using WebService and Memory adapters), which allow to write rich client-side apps talking to server using JSON API.

INSTALLATION

Use npm to install core package:

npm install jugglingdb --save

Alternatively you can install jugglingdb core from github:

npm install 1602/jugglingdb

Then install adapter for specific database, for example jugglingdb-redis:

npm install jugglingdb-redis

See [ADAPTERS][] for list of available adapters.

DOCUMENTATION

Autogenerated documentation available at [jsdoc.info/1602/jugglingdb]. Human-written manual sections are:

  • jugglingdb-schema(3): Everything about schema, data types and model definition.

  • jugglingdb-model(3): Model methods, features and internals.

  • jugglingdb-validations(3): Built-in validators, creating custom validations, syncronous and asyncronous object validation.

  • jugglingdb-hooks(3): Hooks and object lifecycle.

  • jugglingdb-adapter(3): Adapter API explained.

ADAPTERS

All adapters available as separate packages at [github.com/jugglingdb] and published in npm.

  • MySQL: [github][jugglingdb-mysql] [npm][mysql-adapter-npm]
  • SQLite3: [github][jugglingdb-sqlite3] [npm][sqlite3-adapter-npm]
  • Postgres: [github][jugglingdb-postgres] [npm][postgres-adapter-npm]
  • Redis: [github][jugglingdb-redis] [npm][redis-adapter-npm]
  • MongoDB: [github][jugglingdb-mongodb] [npm][mongodb-adapter-npm]
  • CouchDB/nano: [github][jugglingdb-nano] [npm][nano-adapter-npm]
  • Firebird: [github][jugglingdb-firebird] [npm][firebird-adapter-npm]

CONTRIBUTION

You can take part in improvement of jugglingdb codebase and documents. If you see that some improvements can be done to jugglingdb, then fork repository, make proposed changes and then create new pull request. Please remember that your contribution is highly supported. Be sure to follow the discussion in google group and see [github issues][issues] before you make changes. It preferable that you post new comment in google group or in github before you make changes and create pull request.

FUTURE

See jugglingdb-roadmap(3) and [github issues][issues] to catch up current development and see how you can help jugglingdb to grow up.

BUGS

When you find issues, please report them:

Provide test case for reproducing error. When reporting issue to core mention adapter where problem could be reproduced.

HISTORY

See jugglingdb-changelog(3)

JugglingDB is Copyright (C) 2011 Anatoliy Chakkaev http://anatoliy.in

AUTHOR

CONTRIBUTORS

core contributors (more than 1%)

410	Anatoliy Chakkaev       73.9%
 31	Sebastien Drouyer       5.6%
 25	1602                    4.5%
  9	Muneeb Samuels          1.6%
  6	Henri Bergius           1.1%

adapters maintainers

NOTE: Other adapters waits for their maintainers, drop a line to mail@anatoliy.in if you want to maintain some adapter on regular basis.

SEE ALSO

jugglingdb-schema(3)