简体   繁体   中英

Firebase queries "where contains a string"

I'm trying to do a "where" query in Flutter-Firebase to filter by name (if the object name is "Una casa roja" and the user writes "casa", the object must be returned). I don't know who can I do the query. I only have this, but is not what I am looking for:

.where('nombre', isGreaterThanOrEqualTo: nombre, isLessThan: nombre + 'z')

Thanks!

Firestore doesn't support text-search by default. However, there are a few workarounds.

When you register a new user to your app you can store their username in firestore as an array that includes the possible ways you would search for a user (look at the attached image). 在此处输入图像描述

You can do that by splitting the name string.

setSearchParameters(String name) {
        List<String> searchOptions = [];
        String temp = "";
        for (int i = 0; i < name.length; i++) {
          temp = temp + name[i];
          searchOptions.add(temp);
        }
        return searchOptions;
  }

Then you can query the users collection by searching in that array using arrayContains like this:

await usersCollection
        .where('searchOptions', arrayContains: searchText)
        .get()
        .then((value) =>
            value.docs.map((doc) => User.fromSnapShot(doc)).toList());

This solution works for simple cases but if you need advanced search capabilities then you'll have to use a 3rd party service such as Agolia .

Unfortunately, You can't do this. Firebase documentation says that you can't do it. I don't know why firebase doesn't support that. But to do that you can use third-party APIs such as Agolia or Elastic. For more information you can get it in their documentation in this link https://firebase.google.com/docs/firestore/solutions/search

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM