mysql varbinary 转换_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) 问题解决。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值