温馨提示×

sql如何查找字符串中一个字符所有位置

sql
小亿
162
2024-09-03 07:34:46
栏目: 云计算
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在 SQL 中,要查找字符串中一个字符的所有位置,可以使用自定义函数。以下是一个使用 MySQL 的示例,该示例创建了一个名为 find_all_positions 的函数,它接受两个参数:haystackneedle,分别表示要搜索的字符串和要查找的字符。

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'

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读:ReverseFind的用法,查找字符中最后一个字符

0