Arrowment-DB is a simple JSON database library for Node.js projects, similar to Mongoose but with a focus on simplicity and ease of use.
To start using Arrowment-DB in your project, follow these simple steps:
-
Install Arrowment-DB using npm:
npm i arrowment-db
-
Create a new folder named
jsonDB.js
in your project directory. -
In the
jsonDB.js
file, set up the database configuration:// jsonDB.js const { ArrowmentJsonDB } = require("arrowment-db"); const jsonDB = new ArrowmentJsonDB({ data_dir: "path/to/your/data/directory", }); module.exports = { jsonDB };
Replace
"path/to/your/data/directory"
with the actual path to the directory where you want to store your JSON data. IT MUST BE ABSOLUTE PATH -
Congratulations! You have set up your JSON database. Now you can create and manage your JSON data easily.
If you want to add a custom string generator function, you can do so by adding a string_generator
property to the ArrowmentJsonDB
configuration.
To define a schema for your data, follow these steps:
-
Create a new directory named
schema
in your project directory. -
In the
schema
directory, create a new file (e.g.,myschema.js
). -
In the
myschema.js
file, define your schema using theJsonSchema
class:// myschema.js const { jsonDB } = require("../jsonDB"); const { JsonSchema } = require("arrowment-db"); const data = { Name: String, Age: Number, }; const info = new JsonSchema({ schema: data, json_class: jsonDB, name: "Info", });
Make sure to replace
"../jsonDB"
with the actual path to yourjsonDB.js
file.In this example, we define a schema with two fields:
Name
(string) andAge
(number). The schema is associated with theInfo
collection in the database.
Once you have set up your schema, you can start managing your data. Here's how:
To create data, simply const the schema and use the create
method:
const { info } = require("./schema/mySchema.js");
info.create({
Name: "John",
Age: 13,
});
To delete data, specify the query and use the delete
method:
const { info } = require("./schema/mySchema.js");
info.delete({ Age: 13 });
To delete multiple records matching a query, use the deleteAll
method:
info.deleteAll({ Age: 13 });
To find data, use the findData
method:
const data = await info.findData({ Age: 13 });
To find all records matching a query, use the findAllData
method:
const data = await info.findAllData({ Age: 13 });
To save data, use the save
method:
const result = await info.findData({ Age: 13 });
const data = result;
data.Name = "The Rock";
await info.save(data, { Name: "John" });
To update all records matching a query, use the updateAll
method:
const result = await info.findData({ Age: 13 });
const data = result;
data.Name = "The Rock";
await info.updateAll(data, { Name: "John" });
To find a path, use findPath
:
console.log(await personalInfo.findPath({ name: "The Rock" }));
/**
C:/Users/techn/OneDrive/Desktop/Projects/JSON-DB/test/data/PersonalInfo/l5G0U0t2Z7t4x9u5z0q6fd3357708145db3dfbb81709888536.json
*/
To find all the paths, use findAllPath
:
console.log(await personalInfo.findAllPath({ name: "The Rock" }));
/**
[
'C:/Users/techn/OneDrive/Desktop/Projects/JSON-DB/test/data/PersonalInfo/l5G0U0t2Z7t4x9u5z0q6fd3357708145db3dfbb81709888536.json'
]
*/
CHANGES IN 1.2.0
- All methods like
findData
,findAllData
,save
,updateAll
, and their fuzzy versions now return something. findData
,findAllData
,save
,updateAll
,create
, and their fuzzy versions will returnnull
if no data is found.- The methods
findData
andfindAllData
now return only the data, not an object containing the path and the data. findData
andfindAllData
methods returnnull
if no data is found.- Methods
findPath
andfindAllPath
have been added to theJsonSchema
class for finding paths. - Methods
findPath
andfindAllPath
return the file paths directly. fuzzySearchData
,fuzzySearchAllData
,fuzzySearchPath
,fuzzySearchAllPath
,fuzzyDelete
,fuzzyDeleteAll
,fuzzySave
,fuzzyUpdateAll
methods have been added for fuzzy searching and operations.- Added QuickCollection, Its a map() like class but with fuzzy searching.
- Added support for searching nested object structures.
What is fuzzy searching?
Fuzzy searching is a searching method used when you don't have the exact query or only have a rough or approximate query. In such cases, instead of requiring an exact match, fuzzy searching employs algorithms like Levenshtein's algorithm to find the best match and retrieve relevant data. This approach allows for more flexible and forgiving searches, accommodating variations in spelling, typos, or slight deviations from the original query.
To find data using the fuzzy method, use fuzzySearchData
:
console.log(await personalInfo.fuzzySearchData({ name: "Jo" })); //We are not sure of the actual name
/**
{
name: 'John',
Age: 13,
id: 'l5G0U0t2Z7t4x9u5z0q6fd3357708145db3dfbb81709888536'
}
*/
To search all the data and not just one data, use fuzzySearchAllData
:
console.log(await personalInfo.fuzzySearchAllData({ name: "Jo" })); //We are not sure of the actual name
/**
[
{
name: 'John',
Age: 13,
id: 'l5G0U0t2Z7t4x9u5z0q6fd3357708145db3dfbb81709888536'
}
]
*/
To find the path using fuzzy search, use fuzzySearchPath
:
console.log(await personalInfo.fuzzySearchPath({ name: "Jo" })); //We are not sure of the actual name
/**
C:/Users/techn/OneDrive/Desktop/Projects/JSON-DB/test/data/PersonalInfo/l5G0U0t2Z7t4x9u5z0q6fd3357708145db3dfbb81709888536.json
*/
To find all the paths using fuzzy search, use fuzzySearchAllPath
:
console.log(await personalInfo.fuzzySearchAllPath({ name: "Jo" })); //We are not sure of the actual name
/**
[
'C:/Users/techn/OneDrive/Desktop/Projects/JSON-DB/test/data/PersonalInfo/l5G0U0t2Z7t4x9u5z0q6fd3357708145db3dfbb81709888536.json'
]
*/
To delete the data using fuzzy search, use fuzzyDelete
:
await personalInfo.fuzzyDelete({ name: "Jo" }); //We are not
sure of the actual name
To delete all the data using fuzzy search, use fuzzyDeleteAll
:
await personalInfo.fuzzyDeleteAll({ name: "Jo" }); //We are not sure of the actual name
To update one data using fuzzy search, use fuzzySave
:
const s = await personalInfo.fuzzySearchData({ name: "Jo" });
s.name = "TechPowerB";
console.log(await personalInfo.fuzzySave(s, { name: "Jo" })); //We are not sure of the actual name
/**
{
name: 'TechPowerB',
Age: 13,
id: 'l5G0U0t2Z7t4x9u5z0q6fd3357708145db3dfbb81709888536'
}
*/
To update everything using fuzzy search, use fuzzyUpdateAll
:
const s = await personalInfo.fuzzySearchData({ name: "Jo" });
s.name = "TechPowerB";
console.log(await personalInfo.fuzzyUpdateAll(s, { name: "Jo" })); //We are not sure of the actual name
/**
{
name: 'TechPowerB',
Age: 13,
id: 'l5G0U0t2Z7t4x9u5z0q6fd3357708145db3dfbb81709888536'
}
*/