4

Col1假设我的数据库中已经存在一个集合。所以,做类似的事情:

var col = db.collection('Col1');
col.save({"name":"something"});

会很好地工作。

Col2但是,如果我的数据库中不存在的集合尝试使用相同的东西,即

var col = db.collection('Col2');
col.save({"name":"something"})

也可以正常工作。只是它不存在并且不会显示在我的数据库中。如果它抛出了一些错误或我可以使用的东西trycatch结果声明。但既然那是不合时宜的,我怎么知道一个集合是否已经存在?

4

4 回答 4

3

这里有两件事可能会令人困惑。

首先,arangojs(与 ArangoDB 的内部 JS API 不同)对于需要与实际 ArangoDB 服务器通信的所有内容都是异步的。异步函数在文档中被标记为“异步”。

您可以将 node.js 样式的回调(如内置 node.js 模块中的异步函数,例如fshttp等)传递给这些方法。或者,您可以简单地省略回调,该方法将返回结果的承诺。您可以在 Mozilla 的 JavaScript 参考文档中了解有关 Promise 工作原理的更多信息(这不是特定于 Mozilla 的——它们的参考非常好并且通常是正确的)。

您遇到的另一件事是 arangojs 中的集合对象与 ArangoDB 中的实际集合之间的区别。驱动程序允许您为集合创建集合对象,无论它们是否存在。如果集合实际上不存在,则尝试使用它们时,您当然会看到错误。

var col = db.collection('whatever');
col.create() // create the collection if it doesn't exist
.catch(function () {}) // ignore any errors
.then(function () {
  return col.get(); // make sure the collection exists now
})
.then(function () {
  return col.save({some: 'data'});
})
.then(function (result) {
  // everything went fine
})
.catch(function (e) {
  console.error('Something went wrong', e.stack);
});

或使用 async/await (如果您使用 Babel 或一年后阅读此答案):

var col = db.collection('whatever');
try {
  await col.create(); // create the collection if it doesn't exist
} catch (e) {} // ignore any errors
try {
  await col.get(); // make sure the collection exists now
  const result = await col.save({some: 'data'});
  // everything went fine
} catch (e) {
  console.error('Something went wrong', e.stack);
}

或者使用 node.js 风格的回调,因为你是老派或者真的很喜欢金字塔:

var col = db.collection('whatever');
col.create(function () { // create the collection if it doesn't exist
  // ignore any errors
  col.get(function (err) { // make sure the collection exists now
    if (err) {
      console.error('Something went wrong', err.stack);
      return;
    }
    col.save({some: 'data'}, function (err, result) {
      if (err) {
        console.error('Something went wrong', err.stack);
        return;
      }
      // everything went fine
    });
  });
});
于 2016-11-15T16:17:49.050 回答
2

col.save不会立即执行保存操作,而是返回一个 Promise。所以总会成功的。解决方案是等待 promise 被解决,然后对是否发生错误做出反应:

var col = db.collection('Col2');
col.save({"name":"something"}).then(
  meta => console.log('Document saved:', meta._rev),  
  err => { console.error('Failed to save document:', err.errorNum, err.response.body.errorMessage); }
);
于 2016-11-10T13:03:23.990 回答
1

https://docs.arangodb.com/3.1/Manual/DataModeling/Collections/DatabaseMethods.html#collection states

返回单个集合或 null db._collection(collection-name)

所以你可以使用

var col2 = db._collection('Col2');
if (col2) {
    // collection exists
    col2.save({"name":"something"});
}
于 2016-11-09T13:04:26.040 回答
0

这是旧的,但有一个exists()功能。

打字稿/节点中的示例

const metaResult = db.collection('myCollection');
if(!await metaResult.exists()) {
    await db.createCollection('myCollection');
}
于 2020-12-03T13:55:48.643 回答