SQFLite:如何进行 "SELECT table WHERE LIKE '%a word%'" 查询

SQFLite: How to make a "SELECT table WHERE LIKE '%a word%'" query

我是 flutter 和 SQFlite 的新手,我的 'category' 列中有多个实例,在某些插入内容中,我有两个或多个相同值的实例,用“,”分隔,

例如:

'INSERT INTO todos(title, entidad, categoria, emision) VALUES ("title1", "e1", "fire, water, sky", "emi1"');

在那个例子中我在类别列中插入了两个值

我想要的是编写查询类型“like”SQLite 语句,其中包含我想要的词。

我的 dbhelper.dart 中只有这段代码,它工作正常。

Future<List<todo>> categoriaIdiomas() async {
    final db = await initializeDB();

    //this is the query
    final List<Map<String, dynamic>> queryResult =
        await db.rawQuery('SELECT * FROM todos WHERE categoria=?', ['water']);

    Map<String, dynamic> result = {};

    for (var r in queryResult) {
      result.addAll(r);
    }

    return queryResult.map((e) => todo.fromMap(e)).toList();
  }

我想知道如何在 sqflite 中制作这样的东西:

"SELECT todos WHERE categoria LIKE '%water%'"

首先,删除第 categoria 列中单词之间的空格,然后使用运算符 LIKE:

await db.rawQuery("SELECT * FROM todos WHERE ',' || categoria || ',' LIKE '%,' || ? || ',%'", ["water"]);