微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – MySQL – 不区分大小写的搜索

参见英文答案 > PHP/Mysql Search – Case sensitive                                    6个
用户构建我的搜索引擎以搜索三个变量$Title,$Text和$Number …
如何在用户搜索时找到所有结果,无论用户在$query中键入的案例类型(大写或大写)?

$query = trim ($query);

$raw_results = MysqL_query("SELECT * FROM posts
        WHERE (`Number` LIKE '%".$query."%') OR (`Title` LIKE '%".$query."%') OR (`Text` LIKE '%".$query."%') ") or die(MysqL_error());

解决方法

用例不敏感 collation

SELECT * FROM posts
WHERE (`Number` LIKE '%".$query."%') 
OR (`Title` LIKE '%".$query."%') 
OR (`Text` LIKE '%".$query."%')
COLLATE utf8_ci  --'ci' stands for case insensitive: choose the colaltion that fits your encoding

支持的排序规则列表如下:https://dev.mysql.com/doc/refman/5.5/en/charset-charsets.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐