33 mysql find_in_set 的实现

前言

这里我们主要是来探讨一下 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

相关推荐
xiaoye37082 小时前
redis和mysql数据库如何保证数据一致性
redis·mysql
一条闲鱼_mytube2 小时前
MySQL vs PostgreSQL 对比
数据库·mysql·postgresql
小北方城市网3 小时前
Spring Boot 多数据源与事务管理实战:主从分离、动态切换与事务一致性
java·开发语言·jvm·数据库·mysql·oracle·mybatis
invicinble4 小时前
对于mysql层对sql层面的知识体系的理解和把握
数据库·sql·mysql
Nandeska4 小时前
14、MySQL基于GTID的数据同步
数据库·mysql
kyle-fang4 小时前
阿里云服务器部署MySQL
服务器·mysql·阿里云
我是黄骨鱼5 小时前
【零基础学数据库|第二篇】MySql启动!!!
数据库·mysql
Dxy12393102165 小时前
MySQL删除表语句详解
数据库·mysql
uoKent5 小时前
MySQL常见命令梳理大纲
数据库·mysql
予枫的编程笔记5 小时前
【MySQL筑基篇】从排名统计到非结构化存储:MySQL窗口函数与JSON实战教程
mysql·数据处理·窗口函数·后端开发·json数据类型·数据库进阶·mysql高级特性