mysql binary和varbinary存储字段转换大小写

今天在做项目的时候遇到一个功能,需要对字段内容模糊查询,不区分大小写

在建表的时候,使用varchar,char..存储,在查询的时候不区分大小写,name='a' 和 name='A'会得到同样的结果

需要使用binary 辅助才能区分

现在我这里有个相反的例子

其中表 cs_course 中name字段是采取varbinary字段存储的(编码是UTF8)

数据如下

mysql> select name from cs_course;
+--------------------+
| name               |
+--------------------+
| Poetry             |
| Poetry 2           |
| 涓€鍒嗛挶             |
| 璇楁瓕               |
| 瓒呭競鑻辫           |
| 椋炴満鑻辫           |
| ddddd              |
| 鍙hA              |
| 鍙hA              |
| 鍙hB              |

需求是需要模糊查询出相关数据

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)

问题解决。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值