问题很简单,但即使通过互联网和pouchdb源进行详尽搜索,我也找不到检查本地数据库是否存在的函数。
用例是检查本地数据库是否已经存在,然后成功登录可选。
祝你好运
答案 0 :(得分:9)
确实有一个skip_setup
选项。
如the documentation中所述,默认情况下,PouchDB将检查数据库是否存在,并尝试创建它(如果它还不存在)。您可以将此选项设置为true
以跳过此设置。
启用此选项后,如果在查询数据库信息时数据库不存在,则会收到错误,例如:
const db = new PouchDb('DB_URL_OR_NAME', { skip_setup: true });
db.info()
.then(() => {
// The database exists.
// Do something...
})
.catch(e => {
// No database found and it was not created.
// Do something else...
});
答案 1 :(得分:7)
正如akofman所指出的,skip_setup不适用于本地数据库。所以我知道这样做的唯一方法是解决方法 - 检查新数据库是否为空,然后立即删除它。当然,如果有问题的数据库存在但这是空的......
const testdb = new PouchDB('testdb_name');
testdb.info().then(function (details) {
if (details.doc_count == 0 && details.update_seq == 0) {
alert ('database does not exist');
testdb.destroy().then (function() {console.log('test db removed');});
}
else alert ('database exists');
})
.catch(function (err) {
console.log('error: ' + err);
return;
});
答案 2 :(得分:1)
我需要确认数据库已从客户端的浏览器中删除。问题是您只需要删除就需要创建数据库...
Pouch至少在Chrome上存储数据的默认方式是在带有_pouch_前缀的indexedDB中。因此,我只是删除indexedDB数据库。
这是我的代码。它返回一个与PouchDB语法匹配的承诺。
function deletePouchDatabase(dbName) {
return new Promise((resolve, reject) => {
var req = indexedDB.deleteDatabase('_pouch_' + dbName);
req.onsuccess = function () {
resolve(null)
};
req.onerror = function () {
reject(new Error("There was an error"))
};
req.onblocked = function () {
reject(new Error("The operation was blocked"))
};
});
}
因此,您可以使用类似的方法来检查它是否存在。如果存在,则诺言将返回 true ,如果不存在,则返回 false 。
function pouchDatadatabaseExists(dbname) {
return new Promise((resolve, reject) => {
const req = indexedDB.open(`_pouch_${dbname}`);
req.onsuccess = function () {
resolve(true)
}
req.onupgradeneeded = function () {
resolve(false)
}
});
}