0

我从网上尝试了以下基本示例;

var loki = require('lokijs');
var lokiDatabase = new loki('oops.json');

var collection = lokiDatabase.addCollection('props',{
    indices: ['name']
});


function hello() {
    var insertjson = {name:'Ram'};
    collection.insert(insertjson);
    lokiDatabase.saveDatabase();
    var select = collection.findOne({name:'Ram'});
    console.log('select response:'+ select.name);
 }

hello();

我可以通过findOne方法获得输出;

但在这里,问题是;正如教程所说,LokiJS 是一个内存数据库;其中,我可以看到所有插入和更新都显示在 oops.json 文件中。

我们在哪里存储/从内存中存储?

我是不是理解错了概念?

4

2 回答 2

0

Lokijs 是一个文档驱动的数据库,除了不必只存储一个 json 文件的记录外,还可以存储在本地数据库文件中,例如创建 local_database.db。正如前面提到的答案,您必须使用邮递员运行它。当您以 json 格式在请求正文中插入记录 ex:{ "criteria":{"name":"jason"} } 时,它将被插入到 local_database.db 文件中。类似地检索可以调用 get api 的记录。由于要查找特定记录,您可以使用 findOne({name:"jason"})。

于 2019-01-09T14:34:11.157 回答
0

在此处输入图像描述

//lokirouter.js
const db=require('./lokidb')
const router=require('express').Router
class Erouter{
static get(){
router.get("/",(req,res)=>{
db.loadDatabase({},function(){
    try{
    const data=db.getCollection('items').find({})
    res.send(data).status(200)
    }
    catch(r){
        res.status(500).send(`${r}`)
    }
})
})
router.post("/",(req,res)=>{
db.loadDatabase({},()=>{
    try{
    const data=db.getCollection('items').insert(req.body.criteria)
    db.saveDatabase(data)
    db.save(data)
    res.send(data).status(200)
    }
    catch(r){
    res.status(500).send(`${r}`)
    }
    })
    })
return router
}}
module.exports=Erouter

//lokidb.js
var loki=require('lokijs')
var db = new loki('loki.db');
var items = db.addCollection('items');
module.exports=db

//lokiapp.js
const lokirouter=require('./lokirouter')
const express =require("express")
const bodyParser = require('body-parser')
const app=express()
const db=require('./lokidb')
const port=8000;
app.listen(port)
console.log("Server Started"+ " "+port)
app.use(bodyParser.urlencoded({ extended: true }))
app.use(bodyParser.json())
app.use("/",lokirouter.get())
于 2019-01-09T14:17:00.047 回答