Javascript Angularfire2更新所有子节点

Javascript Angularfire2更新所有子节点,javascript,firebase,firebase-realtime-database,angularfire2,Javascript,Firebase,Firebase Realtime Database,Angularfire2,在Firebase,我有一个数据库 我想更新所有子节点(例如67-68的子节点),将键“status”设置为“read” 这就是我获取项目列表的方式 this.listaquery = db.list('https://xxxxxxxx.firebaseio.com/chat/'+this.navParams .get('chatRoom'),{ query: { orderByChild: 'id', equalTo

在Firebase,我有一个数据库

我想更新所有子节点(例如67-68的子节点),将键“status”设置为“read”

这就是我获取项目列表的方式

this.listaquery = db.list('https://xxxxxxxx.firebaseio.com/chat/'+this.navParams .get('chatRoom'),{
          query: {
              orderByChild: 'id',
              equalTo: this.navParams .get('id2')
          }
        });
      }
我知道这是更新孩子的密码

this.listaquery.update('-KnFI98Lnm-BYXxR_zoY',{status:'read'});
但是如果我想用一个命令更新所有的子项,我找到了这个解决方案(我不知道它是否是最好的)

this.listaquery = db.list('https://delega-facile.firebaseio.com/chat/'+this.navParams .get('chatRoom'),{
  query: {
      orderByChild: 'id',
      equalTo: this.navParams .get('id1')
  },
  preserveSnapshot: true
});


this.listaquery
          .subscribe(snapshots => {
              snapshots.forEach(snapshot => {
                  this.listaquery.update(snapshot.key,{status :'read'});
                  /*
                  console.log(snapshot.key)
                  console.log(snapshot.val())
                  */
              });
          })