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 |
| 鍙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) 問題解決。
總結
以上是生活随笔為你收集整理的mysql varbinary 转换_mysql binary和varbinary存储字段转换大小写的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ADO.NET+Access: 3,参数
- 下一篇: 什么是IEC球压测试?