- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在考虑在网络浏览器中使用 JavaScript 存储和检索时间序列数据。我预计每秒有 500 - 5000 个浮点项目进行趋势分析。存储时,每个项目都将具有唯一的标记名称、相同的时间戳 (Date.now()) 和浮点值。
在检索数据时,我通常有兴趣获取单个标记名称的值数组,其中时间戳落在指定范围内。
我的问题是我不理解indexedDb数据模型和API。是否可以通过一次调用存储我的所有新值(为所有 1000 个标签每秒生成一次)?
我用 Dexie 作为 indexedDb 的包装器进行了一些实验,这是我的测试代码:
async function start() {
// Define database
await Dexie.delete('trendDatabase');
var db = new Dexie("trendDatabase");
db.version(1).stores({
trends: '++id,trendId,timestamp,value'
});
console.log ("Using Dexie v" + Dexie.semVer);
// Query Database
var result1 = await db.open();
//add 1000 values for two trends
var trendId1 = "FI-100";
var trendId2 = "FI-200";
var t1 = Date.now();
for (var i=0; i<1000; i++) {
var timestamp1 = t1 - (1000 + i) * 1000;
var value1 = Math.sin(i/10)*8;
var storeResult = await db.trends.add({trendId: trendId1, timestamp: timestamp1, value: value1});
var value2 = Math.cos(i/100)*4;
var storeResult = await db.trends.add({trendId: trendId2, timestamp: timestamp1, value: value1});
}
var t2 = Date.now();
console.log("Took: ", t2 - t1);
var t3 = Date.now();
console.log("Took: ", t3 - t2);
console.log(result3);
var result4 = db.delete();
}
最大的问题是存储速度有多慢。在我的笔记本电脑上,存储 2000 个数据点需要 52 秒(但检索 1000 个数据点只需要 11 毫秒)。在我的拥有 optane 存储的台式机上,存储大约需要 2 秒。无论哪种情况,这都太慢了。我需要能够每秒存储一次,因此我需要 < 1000 毫秒的存储速度,最好是 < 100 毫秒。
是否有更好的方法在indexedDb中构建时间序列数据?
我的一个想法是,我可以一次存储所有趋势的最新 100 点数据,然后为每个趋势写入 100 点数据 block (按每个趋势的循环顺序),以减少写入调用的数量100 倍。这也使得检索最近的数据(在最后 100 秒内)时,当我只想要其中的一小部分时,我最终会获得所有 1000 个标签的值,所以我必须做一些过滤工作剔除不相关的数据。这种方法可能是可行的,但我想在经历所有麻烦之前询问社区,看看是否有更好的方法或任何其他项目/库来完成这样的事情。
最佳答案
很好,您发现可以使用 Table.bulkAdd() 代替 Table.add() (看到您自己对问题的回答)
对于查询部分,我理解您希望在查询中包含标签和时间范围。
我认为标签部分与 trendId 相同?
如果是这样,我建议您迁移架构以使用 [trendId+timestamp] 的复合索引,以提高查询效率。
还建议您将数据库实例保留在 start() 函数之外。在模块中声明它并导出它。
db.js
// db.js
export const db = new Dexie('trendDatabase');
db.version(1).stores({
trends: '++id,trendId,timestamp,value'
});// (Keep version 1 if you or your users have it installed)
// Migrate schema:
db.version(2).stores({
trends: '++id, [trendId+timestamp]'
});
查询.js
// query.js
import { db } from './db';
export function query(trendId, timeFrom, timeTo) {
return db.trends
.where('[trendId+timestamp]')
.between([trendId, timeFrom], [trendId, timeTo])
.toArray();
}
log.js
import { db } from './db';
export async function log(trends) {
await db.trends.bulkAdd(trends);
}
如您所见,您只需对将在 where 子句中使用的属性建立索引。这并不意味着您可以为每个对象存储其他属性。
关于javascript - 使用indexedDb高效存储和检索时间序列数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54789954/
是否可以从浏览器外部或创建它的域外部访问 IndexedDB? 我正在考虑将数据存储到与某个特定域相关的某些 IndexedDB 的情况,因为它总是这种情况,然后在第一个域不复存在后访问该数据,或将其
我有一个员工在断开连接模式下使用的渐进式网络应用程序。他们扫描商店中的库存商品,该应用程序搜索本地数据以查找扫描的商品(indexedDb 数据存储,约有 1/2 百万条记录)。 此数据通过 API
有人可以告诉我是否可以使用 index、openCursor 和 keyRange 在 indexeddb 对象存储上执行不区分大小写的搜索.... 我可以区分大小写并设法使用 toUpperCase
来自提供的示例here和 here 它们展示了创建请求,然后在发出请求后附加 onerror 和 onsuccess 处理程序。 var transaction = db.transaction(["
假设您正在构建一个框架 Foobar,并假设 Foobar 有一个函数 .coolstuff(),它会调用 IndexedDB 调用 .coolstuff2() 和 .coolstuff3(),当这两
只要您使用适当的 IDBTransaction,是否可以从单个事务中完成所有这些操作,而不是打开多个事务(读取表、写入表、写入另一个表等)? Mozilla 说:“保持事务处于事件状态的唯一方法是对其
我有一个小项目,将数据存储在浏览器的 IndexedDB 中。我想添加同步功能,以便用户可以在任何地方访问数据。 如何在远程服务器或服务器数据库中同步本地 IndexedDB 数据,以便我可以在任何地
我想在 onupgradeneeded 中更新我的 indexeddb 数据库的对象库之一。我想检查一下,如果这个索引存在于这个对象存储中,那么就不需要做任何更改。但如果不是,我想更新它的索引。 最佳
有没有办法检查 IndexedDB 数据库是否已经存在?当程序试图打开一个不存在的数据库时,该数据库被创建。 我能想到的唯一方法是如下所示,我测试 objectStore 是否已经存在,如果不存在,则
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我的代码如下: ... var f1 = function(trans) { var store = trans.objectStore('ObjectStore'); store.clear
我在我的一页中创建了一个 IndexdDB 对象存储(让对象存储名称为“ShopStore”)。现在我想从不同的页面打开相同的对象存储。可能吗? 我的两个网页位于不同的域。 最佳答案 根据MDN您无法
我有一个 Epub 注释插件,用户可以在其中对 Epub 进行注释,但是注释文本存储在浏览器中的 indexeddb 数据库中,想将这些注释文本导出到文件中,而在其他系统中,我想将这些文件导入到我的
在之前的 IndexedDB 规范 ( http://www.w3.org/TR/2011/WD-IndexedDB-20111206 ) 中,IDBDatabase 事务的模式值很短。在当前规范(2
有没有办法对 IndexedDB 中的同一属性进行 OR 或 IN 查询? 换句话说,我如何得到结果, SELECT * FROM MyTable WHERE columnA IN ('ABC','D
据我了解,IndexedDB 是大多数跨浏览器在线数据库解决方案的方式。甚至可能在 FF 等浏览器中使用这个 polyfill。 我试图找到一个非常简单的页面,它使用 IndexedDB 最初填充数据
给定一个带有一个声明对象存储的 indexeddb 数据库: var objectStore = thisDb.createObjectStore("table", {keyPath: "id", a
我正在构建一个利用 IndexedBD 的网络应用程序。我来自 SQL 背景,所以概念不同。具体来说,我的理解是 indexedDB 中没有“外键”的真正概念。因此,我试图找出检索相关对象的最快方法,
我在不做任何其他修改的情况下升级版本时遇到此代码问题,我无法理解原因。 function create_registry() { var version = 1; var indexe
我使用下面的代码从 indexeddb 中选择所有列 this._connection.openDb(this._indexedDBLiveDBName); return this._
我是一名优秀的程序员,十分优秀!