MySQL 不包含名为 PATINDEX 的函数,PATINDEX 是 SQL Server 中的一个函数
在 MySQL 中,可以使用 LOCATE()
或者 POSITION()
函数来达到类似的目的。这两个函数都用于在一个字符串中查找子字符串的位置。
语法:
LOCATE(substr, str) POSITION(substr IN str)
其中,substr
是要在 str
中查找的子字符串,str
是要搜索的主字符串。
示例:
SELECT LOCATE('text', 'This is a text string.'); -- 返回 11 SELECT POSITION('text' IN 'This is a text string.'); -- 返回 11
这两个函数在处理大小写时有所不同。LOCATE()
默认是大小写敏感的,而 POSITION()
则是大小写不敏感的。如果需要进行大小写不敏感的搜索,可以将输入字符串转换为统一的大小写形式(如全部转换为小写或大写)。
例如:
SELECT LOCATE(LOWER('Text'), LOWER('This is a Text string.')); -- 返回 11 SELECT POSITION(LOWER('Text') IN LOWER('This is a Text string.')); -- 返回 11
请注意,返回的位置索引是从 1 开始的,而不是从 0 开始。如果子字符串没有在主字符串中找到,LOCATE()
和 POSITION()
函数将返回 0。