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"]);
我是 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"]);