java - firebase 中的 "equalTo"和 "startAt & endAt"有什么不同,什么时候应该使用 "equalTo"或 "startAt and endAt"?

标签 java android firebase firebase-realtime-database kotlin

当我试图通过电子邮件或电话号码查找记录时,我一直在使用下面的两个代码,有时第一个代码工作正常有时不起作用,第二个代码也一样。

下面的代码和什么时候应该使用“equalTo”“startAt and endAt”有什么区别?

ref.orderByChild("email")
            .equalTo(str)

ref.orderByChild("email")
            .startAt(str)
            .endAt(str+"\\uf8ff")

最佳答案

ref.orderByChild("email").equalTo(str)

以上意味着电子邮件必须等于 str 的值。这与说 WHERE email= 'userx@gmail.com'

是一样的
ref.orderByChild("email").startAt(str).endAt(str+"\\uf8ff")

这就像说 WHERE email LIKE ca% 这将返回所有以 "ca" 开头的电子邮件

public Query startAt (String value)

Create a query constrained to only return child nodes with a value greater than or equal to the given value, using the given orderBy directive or priority as default.

public Query endAt (String value)

Create a query constrained to only return child nodes with a value less than or equal to the given value, using the given orderBy directive or priority as default.

The \uf8ff is simply the last character in unicode, so acts as an end guard.

检查此查询:

https://www.youtube.com/watch?v=sKFLI5FOOHs

关于java - firebase 中的 "equalTo"和 "startAt & endAt"有什么不同,什么时候应该使用 "equalTo"或 "startAt and endAt"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51607449/

相关文章:

java - 将字符串转换为 <Integer>ArrayList

java - 迭代数组,检索元素值并将它们相加

VeriSign 签名证书中的 Java SSLHandshakeException

node.js - 设置 Firebase 事务的优先级( Node JavaScript)

android - Firebase 存储 URL 随新 token 不断变化

android - 当点击推送通知时,当应用程序关闭时,如何打开由 Firebase 发送的 url?

java - BufferedReader 创建奇数字符,我应该使用哪种字符编码?

android - 捕获电子邮件验证单击并打开 android 应用程序

java - Android Studio AsyncTask 返回对象困难

android - Android SDK 和 AVD 管理器拒绝连接