前言
这里我们主要是来探讨一下 mysql 中 in 的使用, find_in_set 的使用
这两者 在我们实际应用中应该也是 非常常用的了
测试数据表如下
CREATE TABLE `tz_test` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`field1` varchar(16) DEFAULT NULL,
`field2` varchar(16) DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE,
KEY `field1` (`field1`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8
然后测试数据如下
find_in_set 的实现
找主键测试一下, 可以看到 主键查询 都是使用的全表查询
因此 大概能够猜到 find_in_set 基本上都是需要全表查询的了
explain sql 如下 "select * from tz_test where FIND_IN_SET("field5", field1);"
然后我们来看下一篇 find_in_set 的是实现
sub_select 中全表遍历所有的记录, 然后这里 Item_func_find_in_set 中来进行过滤, 这里的处理类似于 in 的处理, 如果这里校验没有通过, 不响应数据给客户端
find_in_set 的具体实现如下, 就是基础的字符串处理的方式, 来判断 buffer 根据 ","号 分割之后的字符串列表 是否包含 find
完