选择Pouchdb后异步写入

时间:2017-04-26 20:05:45

标签: javascript node.js database asynchronous pouchdb

我试图在将其插入我的bdd之前检查是否存在元素。 我必须这样做才能(将来)修改这个现有元素。

我在节点6.9.1中使用PouchDb和PouchDb-find。

其实我这样做:

for(var i = 0; i < 10;i++ ){
    (function(_count, _pdb){
      var count = _count;
      var db = _pdb;
      db.find({
        selector: {numeroCandidat: parseInt(results[count].no_apb)}
      }).then((result) => {
        if(result.docs.length != 0){
          console.log("l'étudiant existe");
        }else{
          console.log("l'étudiant n'existe pas");

          var etudiant = {
            "numeroCandidat": results[count].no_apb,
            "nom": results[count].nom,
            "numeroGroupe": "gr" + results[count].groupe,
            "filiere": results[count].libelle,
          };

          db.post(etudiant).then((response) =>{
            // handle response
            console.log("STUDENT CREATED");
          }).catch(function (err) {
            console.log(err);
          });
        }
      }).catch(function (err) {
      });
    })(i, this.pdb);
  };

但问题是:由于我的select查询的异步版本...如果一个元素存在两次,它会追加第二个选择在插入第一个元素之前发生,并且我在我的元素中有两次这个元素数据库。我不知道如何处理这个。

1 个答案:

答案 0 :(得分:0)

所以..我发现了一个解决方法! 只需创建一个函数,我在写入数据库后将其称为recursivly。 再见了。

var createStudents = function(_count, _pdb, _students){
    if(_count >= 10) return;
    console.log(_count);
    var count = _count;
    var db = _pdb;
    var students = _students.slice(0);
    db.find({
      selector: {numeroCandidat: parseInt(students[count].no_apb)}
    }).then((result) => {
      if(result.docs.length != 0){
        console.log("l'étudiant existe");
        createStudents(++count,db,results);
      }else{
        var etudiant = {
          "numeroCandidat": students[count].no_apb,
          "nom": students[count].nom,
          "numeroGroupe": "gr" + students[count].groupe,
          "filiere": students[count].libelle,
          "etudiantComms": [
            {"commentaire": students[count].commentaire}
          ]
        };
        db.post(etudiant).then((response) =>{
          // handle response
          console.log("STUDENT CREATED");
          createStudents(++count,db,results);
        }).catch(function (err) {
          console.log(err);
        });
      }
    }).catch(function (err) {
    });
  }

  createStudents(0,this.pdb,results);