https://github.com/jsweb/jsdb
Simple NoSQL like embedded JSON database for modern Node.js applications.
https://github.com/jsweb/jsdb
database embedded javascript js json nosql
Last synced: about 2 months ago
JSON representation
Simple NoSQL like embedded JSON database for modern Node.js applications.
- Host: GitHub
- URL: https://github.com/jsweb/jsdb
- Owner: jsweb
- Created: 2019-01-15T17:59:19.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2022-12-29T18:52:13.000Z (over 3 years ago)
- Last Synced: 2023-03-02T05:31:21.447Z (over 3 years ago)
- Topics: database, embedded, javascript, js, json, nosql
- Language: TypeScript
- Homepage:
- Size: 198 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# @jsweb/jsdb
Simple NoSQL like embedded JSON database for modern Node.js applications.
- Vanilla JSON data store
- Vanilla Javascript API
- Multiple JSON files (one for each store)
- Asynchronous
- Fast enought
Not tested with large applications in production, but recommended for small to medium applications (almost all).
***
- [@jsweb/jsdb](#jswebjsdb)
- [Install](#install)
- [Usage](#usage)
- [JSON files](#json-files)
- [Auto ID](#auto-id)
- [Auto optimization](#auto-optimization)
- [Database intance](#database-intance)
- [Auto timestamps](#auto-timestamps)
- [Methods](#methods)
- [drop (name: string)](#drop-name-string)
- [store(name: string)](#storename-string)
- [Store instance](#store-instance)
- [Methods](#methods-1)
- [parse()](#parse)
- [truncate()](#truncate)
- [push(...args: any[])](#pushargs-any)
- [find(find: function)](#findfind-function)
- [filter(filter: function)](#filterfilter-function)
- [update(value: any, find?: function)](#updatevalue-any-find-function)
- [replace(value: any, find?: function)](#replacevalue-any-find-function)
- [delete(id: string, find?: function)](#deleteid-string-find-function)
- [filterUpdate(value: any, filter: function)](#filterupdatevalue-any-filter-function)
- [filterReplace(value: any, filter: function)](#filterreplacevalue-any-filter-function)
- [filterDelete(filter: function)](#filterdeletefilter-function)
- [TODO](#todo)
## Install
```
npm i -S @jsweb/jsdb
# or
yarn add @jsweb/jsdb
```
## Usage
```javascript
import { Database } from '@jsweb/jsdb'
const db = new Database('base', 'path', 'dir') // or just base/path/dir
const posts = db.store('posts') // a JSON store into db
```
You don't need to create paths or files, **@jsweb/jsdb** will do the trick for you.
The base path directory is relative to de process root directory. It will be automatically detected using `process.cwd()`.
## JSON files
All your data will be stored in JSON files. The root object in the JSON is an Array and expects to store Objects. Like this:
```javascript
[
{ id: '...', name: 'John Doug', age: 28 },
{ id: '...', name: 'Jane Doug', age: 26 },
{ id: '...', name: 'Lorem Ipsum', age: 75 }
]
```
These objects are NoSQL like documents. So, no fixed model is required, they can be completely diferent.
It is just it, simple and vanilla JSON.
And if do you already have a JSON file full of data, just drop it into de database directory. It just works.
## Auto ID
`id` fields will be auto generated for each entry.
Here we have an immutable rule: `id` is only generated by **@jsweb/jsdb** and it is not possible to overwrite it, even if you provide one.
The only way you can edit `id` is editting the JSON file directly.
If you need to look at your data by indexing the value provided by yourself, just include a key/value into the Object.
**@jsweb/jsdb** have simple methods to `find` and `filter` your data by any field or rule.
## Auto optimization
**@jsweb/jsdb** checks `NODE_ENV` enviroment variable to optimize JSON files into db.
If you are running in `production` mode, then JSON will be minimized. Else it will be indented to develop, test or debug.
## Database intance
Just import and instance a database into a base path.
Database instance have a public `get` for the base dir absolute path, and public `get/set` for auto timestamps.
```javascript
import { Database } from '@jsweb/jsdb'
const db = new Database('base', 'path', 'dir')
db.path // get (only) full OS path to database dir
db.timestamps // it is false by default
db.timestamps = true // now it is true
```
### Auto timestamps
Use it to set auto timestamps on/off (default off).
Turning on auto timestamps will include `createdAt` and `updatedAt` automatic fields on all entries. Values will be datetime strings, resulting from `new Date()` native object serialized to JSON.
### Methods
#### drop (name: string)
Use it to drop a store from database. JSON file will be deleted.
```javascript
import { Database } from '@jsweb/jsdb'
const db = new Database('base', 'path', 'dir')
db.drop('posts')
```
#### store(name: string)
Use it to instance a JSON store from database. JSON file will be created, if it not exists.
```javascript
import { Database } from '@jsweb/jsdb'
const db = new Database('base', 'path', 'dir')
const posts = db.store('posts')
```
This method returns a Store instance, with methods to operate data in JSON files.
## Store instance
This istance is the object to interact with JSON data.
Like database instance, store have a public `get` for the JSON file absolute path.
### Methods
All methods from store instance are `async`, so it is necessary to use them in Promise like syntax or with `async/await` functions.
Exemple:
```javascript
import { Database } from '@jsweb/jsdb'
const db = new Database('base', 'path', 'dir')
const posts = db.store('posts')
const allPosts = await posts.parse()
// or
posts.parse().then(allPosts => {
// ...
})
```
#### parse()
Parses data from JSON file and returns it to use in code.
#### truncate()
It is to clean the store data and make it empty.
#### push(...args: any[])
It is just native `Array.push` (but async), adding new entries to data store.
#### find(find: function)
It is just native `Array.find` (but async), picking an entry from data store which match the `find` function return. If none match, returns `undefined`.
#### filter(filter: function)
It is just native `Array.filter` (but async), picking entries from data store which match the `filter` function return. If none match, returns `[]`.
#### update(value: any, find?: function)
Updates an entry in data store by assign `value` to target entry, merging data. Same effect as `Object.assign(entry, value)`.
`value` must be a literal object with `keys/values` for update.
If `id` is present in `value`, the entry for update will be picked by `id`.
Optionally, `find` function can be used like `Array.find(function)` to pick into data store the exact entry for update.
Only entry `id` will be automatically preserved by store because it is immutable, cannot be reassigned.
#### replace(value: any, find?: function)
Works the same way as `update` method, but updates an entry in data store by replacing it. Same effect as `entry = value`.
#### delete(id: string, find?: function)
Deletes an entry from data store.
If `id` is provided, picks the entry by `id` for delete.
Optionally, it is possible to pass `null` for `id` and `find` function can be used like `Array.find(function)` to pick into data store the exact entry for delete.
#### filterUpdate(value: any, filter: function)
As the name suggests, this is a convenient method combining `filter` + `update` methods for batch updates.
`value` must be a literal object with `keys/values` for update.
If `id` is present in `value`, `update` method will be invoked instead and only one entry will be updated by `id`.
Else, `filter` function will be used the way like `Array.filter(function)` to match all entries for update.
#### filterReplace(value: any, filter: function)
Works the same way as `filterUpdate`, but combines `filter` + `replace` methods.
#### filterDelete(filter: function)
Combines `filter` + `delete` methods for batch deletes.
***
## TODO
- [ ] Paginate list results
- [ ] Browser version