MySQL 逗号分隔查询--find_in_set()函数
业务场景:
在使用MySQL的时候,可能的某个字段存储的是一个英文逗号分割的字符串(这里我们不讨论表设计的合理性),如图所示:

我们在查询的时候需要匹配逗号分割中的某个字符串,该怎么查询呢?
find_in_set函数:
函数结构:find_in_set(str,strlist)
- str:要查询的字符串。
- strlist: 字段名,示例中的 business_line_reviewer 字段。
为了方便理解,我们可以认为strlist是由多个str且以英文逗号分割组成的,函数返回的是str在strlist中的位置,返回值的范围在 1 到 N 之间,需要注意的是strlist不能以英文逗号开头。
find_in_set函数用法演示:
select id,business_line_reviewer from org_performance_approver where find_in_set('zt19379', business_line_reviewer) > 0
查询结果:

完美解决了在查询的时候需要匹配逗号分割中的某个字符串的场景。
索引使用情况:
explain select business_line_reviewer from org_performance_approver where find_in_set('zt19379', business_line_reviewer) > 0;

MySQL版本
select version();

总结:
在查阅资料寻求解决方案的时候,看到部分资料说 find_in_set 函数不支持英文逗号分割 ,我使用的 8.0.27 版本是支持的,可能是老版本不支持,这个待求证,也有资料 find_in_set 函数说不支持索引,同样我在使用的时候看了执行计划,也是支持索引的,可能也是老版本不支持。
如有不正确的地方请各位指出纠正。
相关文章:
MySQL 逗号分隔查询--find_in_set()函数
业务场景: 在使用MySQL的时候,可能的某个字段存储的是一个英文逗号分割的字符串(这里我们不讨论表设计的合理性),如图所示: 我们在查询的时候需要匹配逗号分割中的某个字符串,该怎么查询呢&am…...
【物联网应用案例】智能农业的 9 个技术用例
一、农业中的物联网用例 一般而言,农业物联网传感器以及农业物联网应用有多种类型: 1. 气候条件监测 气象站无疑是当今智能农业领域最受欢迎的设备。这款设备集成了多种智能农业传感器,能够在现场对各类数据进行收集,然后迅速将…...
前端开发——ElementUI组件的使用
文章目录 1. Tabs标签页2. 单选框 el-radio3. 复选框 el-checkbox4. 下拉框 el-select5. 表格 el-table6. 对话框 el-dialog7. 文字提示 el-tooltip8. 抽屉 el-drawer 1. Tabs标签页 <template><el-tabs v-model"activeName" tab-click"handleClick&q…...
Unity编写Shader内置各种矩阵和方法介绍
嗨,各位小伙伴们,我是你们的好朋友咕噜铁蛋!今天,我们要来聊一聊关于Unity中编写Shader时内置的各种矩阵和方法。作为Unity开发者,掌握Shader编写是非常重要的一项技能,而了解内置的矩阵和方法将帮助我们更…...
初学者如何使用QT新建一个包含UI界面的C++项目
文章目录 一、下载并安装QT51、下载安装包2、注册/登录账号3、安装qt6 二、新建QT Widget项目1、新建项目并且运行2、易错点:可能运行成功得到UI界面但是会报错(原因是使用了中文路径) 一、下载并安装QT5 1、下载安装包 进入下载网址 Windo…...
韦东山嵌入式Liunx入门驱动开发四
文章目录 一、异常与中断的概念及处理流程1-1 中断的引入1-2 栈(1) CPU实现a ab的过程(2) 进程与线程 1-3 Linux系统对中断处理的演进1-4 Linux 中断系统中的重要数据结构(1) irq_desc 结构体(2) irqaction 结构体(3) irq_data 结构体(4) irq_domain 结构体(5) irq_domain 结构…...
ubuntu基础操作(1)-个人笔记
搜狗输入法Linux官网-首页搜狗输入法for linux—支持全拼、简拼、模糊音、云输入、皮肤、中英混输https://pinyin.sogou.com/linux 1.关闭sudo密码: 终端(ctrl alt t)输入 sudo visudo 打开visudo 找到 %sudo ALL(ALL:ALL) ALL 这一行…...
Spring Cloud2022之OpenFeign使用以及部分源码分析
OpenFeign使用 Feign和OpenFeign Feign是Netflix开发的⼀个轻量级RESTful的HTTP服务客户端,可以使用⽤它来发起请求,进行远程调用。Fegin是以Java接口注解的⽅式调⽤Http请求,而不是像RestTemplate那样,在Java中通过封装HTTP请求…...
【非比较排序】计算排序算法
目录 CountSort计数排序 整体思想 图解分析 代码实现 时间复杂度&优缺分析 CountSort计数排序 计数排序是一种非比较排序,不需要像前面的排序一样去比较。 计数排序的特性总结: 1. 计数排序在数据范围集中时,效率很高,但…...
数据结构与算法 - 数组与二分查找 + Leetcode典型题
1. 什么是数组 数组是存放在连续内存空间上的相同类型数据的集合。 数组可以方便的通过下标索引的方式获取到下标下对应的数据。 C中二维数组在地址空间上也是连续的。 需注意: 数组的下标从0开始。数组内存空间的地址是连续的。数组的元素是不能删的,…...
SQL进阶(三):Join 小技巧:提升数据的处理速度
复杂数据结构处理:Join 小技巧:提升数据的处理速度 本文是在原本sql闯关的基础上总结得来,加入了自己的理解以及疑问解答(by GPT4) 原活动链接 用到的数据:链接 提取码:l03e 目录 1. 课前小问…...
开发知识点-.netC#图形用户界面开发之WPF
C#图形用户界面开发 NuGet框架简介WinForms(Windows Forms):WPF(Windows Presentation Foundation):UWP(Universal Windows Platform):MAUI(Multi-platform App UI):选择控件参考文章随笔分类 - WPF入门基础教程系列...
基于springboot实现流浪动物救助网站系统项目【项目源码+论文说明】
基于springboot实现流浪动物救助网站系统演示 摘要 然而随着生活的加快,也使很多潜在的危险日益突显出来,比如在各种地方会发现很多无家可归的、伤痕累累的、可怜兮兮的动物,当碰到这种情况,是否会立马伸出双手去帮助、救助它们&…...
灰度负载均衡和普通负载均衡有什么区别
灰度负载均衡(Gray Load Balancing)与普通负载均衡的主要区别在于它们服务发布和流量管理的方式。 灰度负载均衡 目的:主要用于灰度发布,即逐步向用户发布新版本的服务,以减少新版本可能带来的风险。工作方式&#x…...
【二分查找】朴素二分查找
二分查找 题目描述 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。 示例 1: 输入: nums [-1,0,3,5,9,12], target 9…...
Windows Docker 部署 Redis
部署 Redis 打开 Docker Desktop,切换到 Linux 内核。然后在 PowerShell 执行下面命令,即可启动一个 redis 服务。这里安装的是 7.2.4 版本,如果需要安装其他或者最新版本,可以到 Docker Hub 中进行查找。 docker run -d --nam…...
什么是VR虚拟现实|虚拟科技博物馆|VR设备购买
虚拟现实(Virtual Reality,简称VR)是一种通过计算机技术模拟出的一种全新的人机交互方式。它可以通过专门的设备(如头戴式显示器)将用户带入一个计算机生成的虚拟环境之中,使用户能够与这个虚拟环境进行交互…...
高性能API云原生网关 APISIX安装与配置指南
Apache APISIX是Apache软件基金会下的顶级项目,由API7.ai开发并捐赠。它是一个高性能的云原生API网关,具有动态、实时等特点。 APISIX网关可作为所有业务的流量入口,为用户提供了丰富的功能,包括动态路由、动态上游、动态证书、A…...
Gradio Dataframe 学习笔记
Gradio Dataframe 学习笔记 0. 简介1. 使用场景2. 测试数据3. 学习代码4. 更多功能5. 学习资源6. 总结 0. 简介 Gradio是一个用于构建交互式机器学习界面的Python库。它可以轻松创建各种类型的界面,包括用于数据可视化和探索的界面。 Gradio Dataframe 组件是 Gra…...
深入理解计算机系统笔记
1.1 嵌套的数组 当我们创建数组的数组时,数组分配和引用的一般原则也是成立的。 例如,声明 int A[5][3]; 等价于下面的声明 typedef int row3_t[3]; row3_t A[5] 要访问多维数组的元素,编译器会以数组起始为基地址, (可能需…...
从地图标注到动态规划:手把手教你用Cesium编辑功能模拟无人机巡检航线
从地图标注到动态规划:手把手教你用Cesium编辑功能模拟无人机巡检航线 想象一下这样的场景:清晨6点,某智慧城市管理中心的监控大屏亮起,操作员小王正在为今天的无人机巡检任务做准备。他需要在30分钟内规划出一条覆盖15平方公里工…...
GD32F4固件库时钟配置详解:如何手动计算PLL参数并自定义系统频率(以168MHz为例)
GD32F4固件库时钟配置详解:如何手动计算PLL参数并自定义系统频率(以168MHz为例) 在嵌入式系统开发中,时钟配置是决定系统性能和稳定性的关键因素。对于GD32F4系列微控制器而言,灵活配置时钟系统不仅能满足不同应用场景…...
别再只会点‘Run All’了!Vivado Simulator波形窗口的5个隐藏技巧,让调试效率翻倍
Vivado Simulator波形窗口的5个隐藏技巧:让调试效率翻倍 第一次打开Vivado Simulator的波形窗口时,那种面对密密麻麻信号的无力感,相信每个FPGA工程师都深有体会。当设计复杂度上升,信号数量呈指数级增长,简单的"…...
一点点了解电路设计软件,protel电路设计软件文件格式转换
电路设计软件可帮助设计电路,好用的电路设计软件更是一大助力。对于电路设计软件,小编在往期文章中有诸多介绍。为增进大家对电路设计软件的了解,本文讲对protel电路设计软件予以介绍,主要内容为如何将protel格式的文件转换为auto…...
VoxCPM-1.5-WEBUI开箱即用:无需本地训练,在线生成高质量语音
VoxCPM-1.5-WEBUI开箱即用:无需本地训练,在线生成高质量语音 1. 语音合成技术的新选择 在数字内容爆炸式增长的今天,语音合成技术正变得越来越重要。从有声读物到虚拟助手,从教育内容到企业宣传,高质量语音的需求无处…...
06. Python函数基础:从基础封装到高阶应用与算法实战
温故知新:从字符到函数的进阶之路在上一节的学习旅程中,我们深入探索了Python中字符串的奇妙世界。我们不仅掌握了字符串的索引与切片操作,学会了如何像手术刀一样精准地提取数据,还熟悉了各种实用的内置方法,如大小写…...
花了两天,让Trae,给我用魔珐星云数字人写了个项目!
文章目录注意代码视频演示项目背景与痛点2.1 行业与社会背景2.2 现有场景的核心痛点分析2.3 项目切入价值总结产品核心功能3.1 语音驱动的自然交互数字人3.2 基于位置感知的智能导航与指路服务(行)3.3 智能科室引导与就医辅助(医)…...
基于Qt6.4的PDF阅读器开发:实现高效章节目录与预览图功能
1. Qt6.4 PDF模块开发环境搭建 第一次接触Qt6.4的PDF模块时,我着实被它的便捷性惊艳到了。相比之前用Qt5.9时折腾第三方库的痛苦经历,现在只需要在安装时勾选一个选项就能获得完整的PDF处理能力,这感觉就像从手动挡升级到了自动驾驶。 开发环…...
Embedding算法入门到精通:拆解腾讯二面必考题,收藏这一篇就够了!
👔面试官:RAG 里用的 Embedding 算法有哪些?你了解过几代演进? 🙋♂️我:Embedding 算法我知道,Word2Vec 嘛,把词变成向量。 👔面试官:Word2Vec 是 2013 …...
VSCode + Qt + Clangd 三件套配置实录:我如何把C++开发体验提升了一个档次
VSCode Qt Clangd 三件套配置实录:我如何把C开发体验提升了一个档次 作为一名长期与C打交道的开发者,我一直在寻找能够提升编码效率的工具组合。经过多次尝试和优化,最终形成了以VSCode为核心,结合Qt框架和Clangd语言服务器的开…...
