Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/firebase/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 按子值进行Firebase搜索_Javascript_Firebase_Firebase Realtime Database - Fatal编程技术网

Javascript 按子值进行Firebase搜索

Javascript 按子值进行Firebase搜索,javascript,firebase,firebase-realtime-database,Javascript,Firebase,Firebase Realtime Database,我的Firebase数据库具有以下结构: 我想按姓名、姓氏或电子邮件搜索用户,但由于我没有上述级别的用户密钥,我不知道如何才能做到这一点。我正在执行和管理员会话,因此它无法访问用户密钥 我试过: let usersRef = firebase.database().ref('users'); usersRef.orderByValue().on("value", function(snapshot) { console.log(snapshot.val()); snapshot

我的Firebase数据库具有以下结构:

我想按姓名、姓氏或电子邮件搜索用户,但由于我没有上述级别的用户密钥,我不知道如何才能做到这一点。我正在执行和管理员会话,因此它无法访问用户密钥

我试过:

let usersRef = firebase.database().ref('users');
usersRef.orderByValue().on("value", function(snapshot) {
    console.log(snapshot.val());
    snapshot.forEach(function(data) {
        console.log(data.key);
    });
});
但它将所有用户都带到数据库中。有什么想法吗?

您可以使用
equalTo()
按值查找任何子项。在您的情况下,请按
名称

ref.child('users').orderByChild('name').equalTo('John Doe').on("value", function(snapshot) {
    console.log(snapshot.val());
    snapshot.forEach(function(data) {
        console.log(data.key);
    });
});
orderByChild()
的目的是定义要筛选/搜索的字段
equalTo()
可以获取字符串、int和布尔值

也可以与自动生成的键(
pushKey
)一起使用


您可以在所有文档中找到一个警告,以避免令人不快的意外:当您使用
orderByChild
equalTo
时,不要忘记在数据上添加索引


如果您不这样做,所有节点都将被下载并过滤到客户端,如果您的数据库增长,这可能会变得非常昂贵。

这是否可以作为一个自动完成系统来完成?例如,如果用户键入“John”,您可以根据相关性调用orderByChild吗?@Epicality您可以使用
startAt()
执行您提到的操作。您可以找到所有文档。但基本上搜索为
equalTo()
,但只检查字符串是否以用户键入开始。如何获取具有两个布尔值字段的节点:第一个字段或第二个字段是
true
?@konstantinkonopkon检查。您可以对数字、字符串、布尔值或null使用
equalTo()
。所以用…来代替我的答案
orderByChild('name')。equalTo(true)
…我猜出来了。我读到了一些由于过时的堆栈溢出材料导致的错误信息。OrderByChild按照您的答案工作。