Advanced Firebase Query with filter in Swift

前端 未结 1 495
臣服心动
臣服心动 2020-12-30 15:15

I just came from the relational database school and dealing with JSON databases is not an easy task for new comers. I have this structure to store users:

{
          


        
相关标签:
1条回答
  • 2020-12-30 15:56

    The to-the-point answer is: You can't do this type is search in Firebase.

    Let me present a wall-of-text answer that will hopefully lead to a solution.

    To Be Quite Frank: As Frank had mentioned in his on-point comments and links, leveraging other products such as ElasticSearch can be one solution. While they do provide scalability, it adds another product to the equation. I would suggest exploring those options further.

    Filtering is Cool: A second solution is to filter in code. While this is a good solution for a couple thousands records, it's not scalable for tens/hundreds of thousands of records. However, this is the best solution if you have a complex data structure and a limited amount of data.

    On that note, you can filter in code even with millions of records if the UI is structured to make it work. Decide on one to or two main searches, gender for example. Then perform a query for all females. That cuts your dataset by half and is much more manageable in code. You can also further reduce your dataset - see next section.

    Change is good: Another option is to structure your data to match the types of queries you will be performing. For a simple example: Suppose you have three items you want to query on; gender_country_age

    Your Firebase structure would be

    users
      -Jyiai09jsi
        data: "male_US_40"
      -Jqkjisjida
        date: "male_US_27"
      -JyHYjlkall
        data: "male_US_30"
    

    Then to query for all male users in the US between the ages of 30 and 40

    usersRef.queryOrderedByChild("data").queryStartingAtValue("male_US_30")
            .queryEndingAtValue("male_US_40").observeSingleEventOfType(
           .Value, withBlock: { snapshot in
        print(snapshot)
    })
    

    The upside here is that's it's scalable but the downside is you can't query for just US users. On the flip side, this is a much smaller dataset which you could further filter in code.

    Duplicate data is your friend: The good news is there's a solution for that as well: disk space is cheap so duplicate your data

    user_countries
       US
           -Jyiai09jsi: true
           -Jqkjisjida: true
           -JyHYjlkall: true
       UK
          etc etc
    
    user_gender
       male
           -Jyiai09jsi: true
           -Jqkjisjida: true
           -JyHYjlkall: true
       female
           etc etc
    
    user_speaks
       da_UK
          users
       fr_FR
          users
    

    This structure give you super quick access to data groups; countries, gender etc. I used true here as a placeholder but technically you could have each users node in that spot as well. But, that would again be reading in a lot of data during the query; a bunch of 'true' nodes is a pretty tiny amount of data, even with thousands of nodes.

    SQL ftw! Something else to consider is how you are using the asynchronous nature of Firebase. Do you really need to have that data stored in Firebase or can you store that data in another cloud based SQL server for queries and store links to that data within Firebase. That way you can SQL query to your hearts content and then use Firebase for messaging, updates etc.

    Final thought Your best bet if you want to to these kinds of searches is to structure your data in a way that reduces it's footprint as quickly as possible, then filter the rest in code. Imagine having a million records and then querying for male_US_30_FR. Now you have a couple of thousand records that's easily loaded and further filtered in code

    I hope one or a combination of these helps.

    0 讨论(0)
提交回复
热议问题