Большое количество данных в indexedDB в Firefox OS
У меня есть большой объем данных, которые я хочу вставить в базу данных indexedDB.
Размер данных около 5МБ.
И более 77 000 строк.
И я преобразовал базу данных в файл "all.js" следующим образом:
const AllData = [
{ id: 1, en: "10th", ar: "arabic word" },
{ id: 2, en: "1st", ar: "arabic word" },
{ id: 3, en: "2nd", ar: "arabic word" },
{ id: 4, en: "3rd", ar: "arabic word" },
{ id: 5, en: "4th", ar: "arabic word" },
{ id: 6, en: "5th", ar: "arabic word" },
{ id: 7, en: "6th", ar: "arabic word" },
{ id: 8, en: "7th", ar: "arabic word" },
{ id: 9, en: "8th", ar: "arabic word" },
to about 77,000
];
и мой код в HTML и JavaScript
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="all.js" type="text/javascript"></script>
<script type="text/javascript">
/*
var custom = [
{"id":1 ,"name":"hussein","email":"test@gmail.com"},
{"id":2 ,"name":"ali","email":"test2@gmail.com"}
];
*/
var db;
var request = window.indexedDB.open("YesData13", 1);
request.onerror = function(event) {
alert("Why didn't you allow my web app to use IndexedDB?!");
};
request.onsuccess = function(event) {
db = event.target.result;
/*
var transaction = db.transaction(["data"], "readwrite");
transaction.oncomplete = function(event) {
alert("All done!");
};
transaction.onerror = function(event) {
// Don't forget to handle errors!
};
var objectStore = transaction.objectStore("data");
for (var i in AllData) {
var request = objectStore.add(AllData[i]);
request.onsuccess = function(event) {
// event.target.result == customerData[i].ssn;
};
}
*/
};
request.onupgradeneeded = function(event) {
var db = event.target.result;
var objectStore = db.createObjectStore("data", { keyPath: "id" });
//objectStore.createIndex("en","en",{unique:true});
//objectStore.createIndex("ar","ar",{unique:false});
for (var i in AllData){
objectStore.put(AllData[i])
}
};
/*
for (var i in AllData) {
var request = objectStore.add(AllData[i]);
request.onsuccess = function(event) {
// event.target.result == customerData[i].ssn;
};
}
*/
function read() {
var transaction = db.transaction(["data"]);
var objectStore = transaction.objectStore("data");
var request = objectStore.get(25001);
request.onerror = function(event) {
alert("Unable to retrieve daa from database!");
};
request.onsuccess = function(event) {
// Do something with the request.result!
if(request.result) {
alert("id: " + request.result.id + ", English: " + request.result.en + ", arabic: " + request.result.ar);
} else {
alert("Kenny couldn't be found in your database!");
}
};
}
</script>
</head>
кликните сюда
Приведенный выше код хорошо работает в Firefox и Google Chrome, и все строки вставлены. но когда попробуйте это в Firefox OS Simulator, он не работает, а когда попытаться уменьшить количество строк до 25000, он работает нормально.
и я пытаюсь разбить его на файлы по 25000 в каждом файле, только первые 25000 добавлены, но после 25000 не добавлены
1 ответ
Из моих собственных экспериментов с indexedDB на Firefox OS кажется, что симулятор накладывает довольно небольшое ограничение на объем данных, которые вы можете хранить с indexedDB. Я попытался написать скрипт для добавления группы случайных данных в одну базу данных, и симулятор не выдал мне ошибку, но он перестал позволять мне добавлять данные после примерно 12 000 записей. Однако, если я попытался создать новую базу данных с помощью симулятора, он выдал ошибку, сообщив, что квота превышена.
Однако, когда я запускал все это на телефоне, он просто продолжал работать, я подозреваю, что симулятор просто не является представителем реального устройства, так как приложения Firefox предположительно не устанавливают ограничение indexedDB. Так что ваше приложение должно работать на устройстве, если у вас есть доступный для тестирования.