MySql精确匹配“,“分隔开的内容的函数语法

最近有一个需求,主表和从表关系是一对多的,但是查询的时候要把从表的字段作为查询条件,且要把匹配到的所有数据进行填充
因此就出现问题了,例如:我传入type=5 如果用 like 去匹配,就会匹配出25,55,255的数据,但是这些都不是要返回的
前提:已经将从表拼接在一起了

SELECT order_no,
        GROUP_CONCAT(DISTINCT type_id) AS typeId,
        GROUP_CONCAT(DISTINCT type_name) AS typeName
        FROM A
        GROUP BY order_no)

解决:

AND FIND_IN_SET(#{dto.type}, type_id) > 0

函数解释:

FIND_IN_SET是 MySQL 提供的一个函数,用于在逗号分隔的字符串中查找某个值是否存在。它返回找到的值在字符串中的位置(从 1 开始),如果找不到,则返回 0

完美解决 end。

MySQL 中的 `SUBSTRING_INDEX` 函数是一个非常实用的字符串处理函数,用于根据指定的分隔符将字符串分割,并返回指定位置的子字符串。 ### 函数语法 `SUBSTRING_INDEX(str, delim, count)` - `str`:需要处理的原始字符串。 - `delim`:分隔符,字符串将根据该分隔符进行分割。 - `count`:返回分割后的第几个子字符串。 - 如果 `count` 为正数,则从左向右计数,返回第 `count` 个子字符串。 - 如果 `count` 为负数,则从右向左计数,返回第 `count` 个子字符串。 ### 常见用法示例 #### 1. 获取第一个子字符串 ```sql SELECT SUBSTRING_INDEX('www.wikidm.cn', '.', 1); ``` 结果:`www` #### 2. 获取前两个子字符串 ```sql SELECT SUBSTRING_INDEX('www.wikidm.cn', '.', 2); ``` 结果:`www.wikidm` #### 3. 获取最后一个子字符串 ```sql SELECT SUBSTRING_INDEX('www.wikidm.cn', '.', -1); ``` 结果:`cn` #### 4. 获取中间子字符串 ```sql SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('www.wikidm.cn', '.', 2), '.', -1); ``` 结果:`wikidm` #### 5. 处理超过实际分隔符个数的情况 ```sql SELECT SUBSTRING_INDEX('http:///www.baidu.com', '.', 3); ``` 由于字符串中有两个 `.`,当 `count` 为 3 时,返回整个字符串。结果:`http:///www.baidu.com`[^2] ### 字符串拆分为多行 `SUBSTRING_INDEX` 也可以结合系统表(如 `mysql.help_topic`)将字符串拆分为多行。例如,将字符串 `'11,22,33,44,55'` 按逗号分割为多行。 ```sql SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('11,22,33,44,55', ',', help_topic_id + 1), ',', -1) AS a FROM mysql.help_topic WHERE help_topic_id < (LENGTH('11,22,33,44,55') - LENGTH(REPLACE('11,22,33,44,55', ',', '')) + 1); ``` - `help_topic_id` 是 `mysql.help_topic` 系统表中的自增列,用于生成序列号。 - `LENGTH(str) - LENGTH(REPLACE(str, ',', '')) + 1` 计算字符串中逗号分隔的元素数量。 - `SUBSTRING_INDEX(SUBSTRING_INDEX(...), ',', -1)` 提取每个分割后的子字符串[^1]。 ### 总结 `SUBSTRING_INDEX` 是 MySQL 中处理字符串的强大工具,能够根据分隔符快速提取特定位置的子字符串,同时结合系统表还可以实现字符串的拆分为多行操作。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值