假设我有这样的结构:
-users
-user1_uid
name
distance
age
我如何进行查询(查找距离<100且年龄介于20到25之间的用户)?
我尝试过标准方法
let recentPostsQuery = (ref?.child("users").queryOrderedByChild("age").queryStartingAtValue("20"))!
M问题是,似乎不可能查询多个孩子(例如结合年龄和距离过滤)。几个月前与Firebase相比,这方面有什么变化吗?我相信,在第一次查询后在本地过滤它们不是一种选择,因为可能存在数千个对象。
答案 0 :(得分:8)
我的第一选择是查询20到25之间的所有用户,然后在代码中过滤距离<1的用户。 100。
问题表明代码中的过滤不是一种选择,但是我希望将其包含在完整性中,以适应几千个节点或更少的节点:
struct User { //starting with a structure to hold user data
var firebaseKey : String?
var theAge: Int?
var theDistance: Int?
}
var userArray = [User]() //the array of user structures
usersRef.queryOrderedByChild("age").queryStartingAtValue(20)
.queryEndingAtValue(25).observeEventType(.Value, withBlock: { snapshot in
for child in snapshot.children { //.Value so iterate over nodes
let age = child.value["age"] as! Int
let distance = child.value["distance"] as! Int
let fbKey = child.key!
let u = User(firebaseKey: fbKey, theAge: age, theDistance: distance)
userArray.append(u) //add the user struct to the array
}
//the array to contain the filtered users
var filteredArray: [User] = []
filteredArray = userArray.filter({$0.theDistance < 100}) //Filter it, baby!
//print out the resulting users as a test.
for aUser in filteredArray {
let k = aUser.firebaseKey
let a = aUser.theAge
let d = aUser.theDistance
print("array: \(k!) \(a!) \(d!)")
}
})
}
现在是一个潜在的超级简单答案。
let usersRef = self.myRootRef.childByAppendingPath("users")
usersRef.queryOrderedByChild("age").queryStartingAtValue(20)
.queryEndingAtValue(25).observeEventType(.ChildAdded, withBlock: { snapshot in
let distance = snapshot.value["distance"] as! Int
if distance < 100 {
let age = snapshot.value["age"] as! Int
let fbKey = snapshot.key!
print("array: \(fbKey) \(age) \(distance)")
}
})
请注意,我们正在利用.ChildAdded而不是.Value,因此每次只读取一个节点 - 如果距离不是我们想要的,我们可以忽略它并继续下一个。
答案 1 :(得分:1)
Firebase无法始终结合条件。 Here
但是,使用新的firebase API,这篇文章可以提供一些提示: How to query based on multiple conditions in Firebase?