Lokijs 在 Node JS 环境中给出不正确的查找响应
这是从网上截取的一个例子:
// This database has already been created for you.
// var db = new loki('sandbox');
// Add a collection to the database
var items = db.addCollection('items');
// Add some documents to the collection
items.insert({ name : 'mjolnir', owner: 'thor', maker: 'dwarves' });
items.insert({ name : 'gungnir', owner: 'odin', maker: 'elves' });
items.insert({ name : 'tyrfing', owner: 'Svafrlami', maker: 'dwarves' });
items.insert({ name : 'draupnir', owner: 'odin', maker: 'elves' });
// Find and update an existing document
var tyrfing = items.findOne({'name': 'tyrfing'});
tyrfing.owner = 'upated';
// These statements send to Text Output
logText('tyrfing value :');
logObject(tyrfing);
logText('tyrfing items');
logObject(items.find({ 'name': 'tyrfing' }));
// This statement sends to Inspector
inspectObject(db);
插入一对虚拟数据后;我从同一个集合中获取并将其分配给一个名为“tyrfing”的 templ 变量;
现在,这是问题所在;我使用名为“upated”的新值对所有者属性进行了更新。尽管我没有对更新进行 loki 保存/更新;
当我将 find on name 称为“tyrfing”时,它给出的响应为
odins items
[
{
"name": "tyrfing",
"owner": "upated",
"maker": "dwarves",
"meta": {
"revision": 0,
"created": 1554823595464,
"version": 0
},
"$loki": 3
}
]
这是不正确的,我希望响应中的所有者名称为“Svafrlami”;因为我没有进行任何数据库提交;
请纠正我,如果我在这里做错了什么;
您可以通过复制粘贴在此处在线测试此代码:http ://www.obeliskos.com/LokiSandbox/