在 SQL 中,要查找字符串中一個(gè)字符的所有位置,可以使用自定義函數(shù)。以下是一個(gè)使用 MySQL 的示例,該示例創(chuàng)建了一個(gè)名為 find_all_positions
的函數(shù),它接受兩個(gè)參數(shù):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 ;
現(xiàn)在你可以使用這個(gè)函數(shù)來查找字符串中一個(gè)字符的所有位置。例如,要查找字符串 'hello world'
中字符 'l'
的所有位置,可以使用以下查詢:
SELECT find_all_positions('hello world', 'l');
這將返回結(jié)果 '3,4,9'
,表示字符 'l'
出現(xiàn)在位置 3、4 和 9。如果字符未找到,則返回 'Not found'
。