我想通过字符串匹配从sqlite3数据库选择记录。但是如果我在where子句中使用'=',我发现sqlite3是区分大小写的。有人能告诉我如何使用字符串比较不区分大小写吗?
当前回答
另一种选择可能对您的情况有意义,也可能没有意义,那就是实际上有一个单独的列,其中包含现有列的预先低分值。可以使用SQLite函数LOWER()填充该列,然后可以对该列执行匹配。
显然,它增加了冗余和潜在的不一致性,但如果您的数据是静态的,它可能是一个合适的选择。
其他回答
如果列的类型是char,那么你需要用空格来附加你正在查询的值,请参考这里的问题。除此之外,还可以使用COLLATE NOCASE或其他解决方案(upper()等)。
这不是特定于sqlite,但你可以这样做
SELECT * FROM ... WHERE UPPER(name) = UPPER('someone')
像这样使用
"select * from $pwsXDataHistory where type = '$type' COLLATE NOCASE and $t_uStatus != '$DELETE' order by $t_name COLLATE NOCASE asc ");
另一种选择可能对您的情况有意义,也可能没有意义,那就是实际上有一个单独的列,其中包含现有列的预先低分值。可以使用SQLite函数LOWER()填充该列,然后可以对该列执行匹配。
显然,它增加了冗余和潜在的不一致性,但如果您的数据是静态的,它可能是一个合适的选择。
可以使用like查询将各自的字符串与表值进行比较。
Select column name from table_name where column name like '各自的比较值';