Notice: Currently unmaintained. This GitHub repo may be un-archived at a later date, should we use this library in the future.
nquiringminds IoT Database utilities (sqlite implementation for now)
npm install nqm-iot-database-utils
npm test
npm run docs
const sqliteUtils = require("nqm-iot-database-utils");
The below example will do the following steps:
- Create a sqlite database in memory with
openDatabase
- Create a dataset with two fields with
createDataset
- Add 100 documents to the dataset with
addData
- Retrieve a list documents for a given filter with
getData
"use strict";
const sqliteUtils = require("nqm-iot-database-utils");
const TDX_SCHEMA = {
"schema": {
"dataSchema": {
"prop1": {
"__tdxType": ["number"],
},
"prop2": {
"__tdxType": ["number"],
},
},
"uniqueIndex": [],
},
};
let dbIter;
const testData = [];
sqliteUtils.openDatabase("", "memory", "w+")
.then((db) => {
dbIter = db
return sqliteUtils.createDataset(db, TDX_SCHEMA);
})
.then(() => {
for (let idx = 0; idx < 100; idx++) {
testData.push({
prop1: idx,
prop2: 100 - idx - 1,
});
}
return sqliteUtils.addData(dbIter, testData);
})
.then(() => {
return sqliteUtils.getData(dbIter,
{$and: [{$or: [{prop1: {$gte: 2, $lte: 5}}, {prop1: {$gte: 92}}]}, {prop2: {$lte: 10}}]},
null,
{
sort: {
prop1: 1,
prop2: -1,
},
});
})
.then((result) => {
console.log(result);
});
The below example will add an ndarray to the dataset:
- Create a sqlite database in memory with
openDatabase
- Create a dataset with two fields with
createDataset
- Add 1 documents to the dataset with
addData
- Retrieve the documents with
getData
"use strict";
const sqliteUtils = require("nqm-iot-database-utils");
const TDX_SCHEMA = {
"schema": {
"dataSchema": {
"timestamp": {
"__tdxType": ["number"],
},
"array": {
"__tdxType": ["ndarray"],
},
},
"uniqueIndex": [],
},
};
let dbIter;
const testData = [];
sqliteUtils.openDatabase("", "memory", "w+")
.then((db) => {
dbIter = db
return sqliteUtils.createDataset(db, TDX_SCHEMA);
})
.then(() => {
const array = new Float64Array(23 * 34);
array.fill(-1.8934579345);
let arrayData = sqliteUtils.getNdarrayMeta(Buffer.from(array.buffer), "float64", [23, 34]);
return sqliteUtils.addData(dbIter, {timestamp: 123456789, array: arrayData});
})
.then(() => {
return sqliteUtils.getData(dbIter, null, null, null);
})
.then((result) => {
const row = result.data[0];
const floatBuffer = sqliteUtils.getTypedArrayFromBuffer(row.array.data, "float64");
console.log(floatBuffer);
});
- Online Website https://nqminds.github.io/nqm-iot-database-utils/module-sqlite-manager.html
- Local Markdown
./docs/api.md