An easy and quick database
Find a file
2023-02-05 13:06:21 +01:00
.github/workflows config 2023-02-05 13:06:21 +01:00
src 2023.02.05-1 2023-02-05 12:20:17 +01:00
.gitignore 2022.12.29 - Init 2022-12-29 11:51:37 +00:00
.npmrc Reset 2022-11-03 17:53:46 +01:00
package.json 2023.02.05-1 2023-02-05 12:20:17 +01:00
readme.md 2023.02.05-1 2023-02-05 12:20:17 +01:00
readmeold.txt map to mit 2023-02-05 12:15:49 +01:00
tsconfig.json map to mit 2023-02-05 12:15:49 +01:00

Mit.db

MapDB A Map that stores data locally and loads it at startup. Written in JavaScript

How does it work?

Map.db works just like the JavaScript built-in Map, with the same methods and functionalities, and in fact it uses itself a Map, but while the built-in Map only stores data in internal memory, this module stores data locally in a file and loads it back in the Map at startup.

The purpose of this module is to make the JavaScript built-in Map an actual database, and there comes the name mit.db: a Map that can be used as a database.

The file structure is easily accessible and the data is stored in JSON format, allowing manual editing

You also have the option to only use local storage without touching internal memory

Differences

Although this module works in fact the same way as a Map, there are still some little differences between them, which are listed below:

  • Mit#set() and Mit#delete() return promises
  • When a value is reassigned to a key, it is only saved in the Map but not in the actual save file, so you always have to set the key/value pair with the new value. Example:
const { MapDB } = require('mit.db');
const mapdb = new MapDB('file.db'); // this is the save file's name + extension
async function sample() {
    // assuming 'somekey' exists in the Map and has a value { cool: false }
    const data = mapdb.get('somekey');
    // reassigning the 'cool' property a new value
    data.cool = true;
    await mapdb.set('somekey', data);
    // now 'somekey' has a new value { cool: true }
}

Docs

Installation

With npm:

npm i mit.db

Setup

const { MapDB } = require('mit.db')
const db = new MapDB('database.json') // this is the save file's name + extension

set()

await db.set('what', 'how')

get()

var answ = db.get('what') // answ = how