gpt4 book ai didi

javascript - Firebase实时数据库: how to check if child value exists

转载 作者:行者123 更新时间:2023-12-03 06:12:45 25 4
gpt4 key购买 nike

鉴于以下文档。

website:{
uid1:{
foo:"bar",
username:"joff"
},
uid2:{
foo:"bar2",
username:"karla"
}
}

我正在尝试使用下面的查询检查用户名是否已存在。

var ref = db.ref('website');
var queryString = 'joff';

ref.orderByChild('username').equalTo(queryString).once('value', function(snap){
if(snap.exists()){
// exists
return
}
console.log('available');
})

这种方法工作没有问题,如果我相应地更改queryString,无论它存在与否,我都会得到我想要的结果。

Firebase 的默认查询限制是 100,我可以根据文档将其更改为我喜欢的。

但是如果我要查询 10,000 文档怎么办?我不能在这里使用分页查询,因为如果查询匹配位于第二页怎么办?我如何处理如此大量的数据?会不会等很久才会有反应?进行此类查询的正确方法是什么。

PS

我严格要求数据模型与上面给出的相同。

提前致谢。

最佳答案

我认为使用 equalTo 生成了一个“智能”查询,因此查询限制不会成为确定记录是否存在的因素。但我并不积极。您是否确实验证过,如果记录超过 100 条,而您的“joff”在排序中的位置超过 100,则会导致不匹配?

如果是这种情况(这将非常令人惊讶),那么您可能可以像这样重构您的查询:

ref.orderByChild('username').startAt(queryString).endAt(queryString).once('value', function(snap){
if(snap.exists()){
// exists
return
}
console.log('available');
})

...但同样,我认为使用 equalTo 时不需要这样做。

关于javascript - Firebase实时数据库: how to check if child value exists,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39249445/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com