今天在做项目的时候遇到一个功能,需要对字段内容模糊查询,不区分大小写
在建表的时候,使用varchar,char..存储,在查询的时候不区分大小写,name='a' 和 name='A'会得到同样的结果
需要使用binary 辅助才能区分
现在我这里有个相反的例子
其中表 cs_course 中name字段是采取varbinary字段存储的(编码是UTF8)
数据如下
mysql> select name from cs_course;
+--------------------+
| name |
+--------------------+
| Poetry |
| Poetry 2 |
| 涓€鍒嗛挶 |
| 璇楁瓕 |
| 瓒呭競鑻辫 |
| 椋炴満鑻辫 |
| ddddd |
| 鍙hA |
| 鍙hA |
| 鍙hB |
需求是需要模糊查询出相关数据
mysql> select name from cs_course where name like '%p%';
+--------------+
| name |
+--------------+
| think in php |
+--------------+
1 row in set (0.00 sec)
这不是我想要的,因为我的字段用的是varbinary存储,mysql 会区分大小写,而我想要的是不区分大小写,连同大写的P的内容一并查找出来,于是想到把字段转换成小写再来匹配
mysql> select lower(name) from cs_course;
+--------------------+
| lower(name) |
+--------------------+
| Poetry |
| Poetry 2 |
| 涓€鍒嗛挶 |
| 璇楁瓕 |
| 瓒呭競鑻辫 |
| 椋炴満鑻辫 |
发现然并卵。
网上找了一下答案,发现需要转换编码后才能对其使用lower或upper
转换编码 convert(field using utf8)
mysql> select lower(convert(name using utf8)) from cs_course;
+---------------------------------+
| lower(convert(name using utf8)) |
+---------------------------------+
| poetry |
| poetry 2 |
| 一分钱 |
| 诗歌 |
| 超市英语 |
| 飞机英语 |
| ddddd |
| 口语a |
| 口语a |
于是乎,最后得到查询
mysql> select name from cs_course where lower(convert(name using utf8)) like '%p%';
+--------------+
| name |
+--------------+
| Poetry |
| Poetry 2 |
| think in php |
+--------------+
3 rows in set (0.00 sec)
问题解决。