在 Yii 2.0 中,使用 like 操作符查找 \ ,结果为空的分析,原因在于 MySQL 版本的官方 Bug

1、请求参数:filter[and][0][or][0][title][like]=\,生成 SQL 如下,查找结果为空。如图1

图1

`pa_plan`.`title` LIKE '%\\\\%'

2、查看表 plan 中的字段 title 的值,其中一条记录存在 \。理论上能够查询出一条记录才是。如图2

图2

3、在 MySQL 客户端软件 Navicat for MySQl 中执行 SQL,4 根反斜杠,查找结果为空。如图3

图3

SELECT * FROM `pa_plan` WHERE `title` LIKE '%\\\\%'

4、查看表 plan 中的字段 title 的排序规则,其值为:utf8mb4_unicode_ci。如图4

图4

5、执行 SQL,5 根反斜杠(添加 1 根),查询出一条记录。如图5

图5

SELECT * FROM `pa_plan` WHERE `title` LIKE '%\\\\\%'

6、修改表 plan 中的字段 title 的排序规则,其值为:utf8mb4_general_ci。如图6

图6

7、执行 SQL,4 根反斜杠,查询出一条记录。如图7

图7

SELECT * FROM `pa_plan` WHERE `title` LIKE '%\\\\%'

8、查看 MySQL 官方文档,参考:https://bugs.mysql.com/bug.php?id=81990 。在 MySQL 版本:5.6.31/5.7.13 中,排序规则,其值为:utf8mb4_unicode_ci 时,皆需要针对 \ 的搜索,再添加 1 根,才能够搜索出结果。此 Bug 在 MySQL 版本:8.0.18 得以修复。如图8

图8

9、查询当前数据库版本:5.7.19。如图9

图9

10、后续确认一下能否在 Yii 2.0 中针对 like \ 的搜索生成 SQL,自动再添加 1 根 \ 。此问题,先暂缓处理。因为像其他的特殊字符的搜索是正常的。

 

永夜