阅读量:0
在 SQL 中,要查找字符串中一个字符的所有位置,可以使用自定义函数。以下是一个使用 MySQL 的示例,该示例创建了一个名为 find_all_positions 的函数,它接受两个参数:haystack 和 needle,分别表示要搜索的字符串和要查找的字符。
DELIMITER $$
CREATE FUNCTION find_all_positions(haystack TEXT, needle CHAR(1)) RETURNS TEXT
BEGIN
DECLARE position INT;
DECLARE result TEXT;
SET position = LOCATE(needle, haystack);
SET result = '';
WHILE (position > 0) DO
SET result = CONCAT(result, ',', position);
SET haystack = SUBSTRING(haystack, position + 1);
SET position = LOCATE(needle, haystack);
END WHILE;
IF (CHAR_LENGTH(result) > 0) THEN
SET result = SUBSTRING(result, 2);
ELSE
SET result = 'Not found';
END IF;
RETURN result;
END$$
DELIMITER ;
现在你可以使用这个函数来查找字符串中一个字符的所有位置。例如,要查找字符串 'hello world' 中字符 'l' 的所有位置,可以使用以下查询:
SELECT find_all_positions('hello world', 'l');
这将返回结果 '3,4,9',表示字符 'l' 出现在位置 3、4 和 9。如果字符未找到,则返回 'Not found'。
以上就是关于“sql如何查找字符串中一个字符所有位置”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm