最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
如何在SQL中查找特定字符在字符串中出现的位置?
时间:2026-06-22 11:52:03 编辑:袖梨 来源:一聚教程网
LOCATE()返回子串首次出现的起始位置(从1开始计数),未找到返回0;参数顺序为LOCATE(子串, 字符串[, 起始位置]),支持第三个参数指定搜索起点,大小写敏感性由collation决定。
MySQL 中用 LOCATE() 找字符位置
MySQL 没有 INSTR() 的标准 SQL 版本,但 LOCATE() 是最直接的选择。它返回子串首次出现的起始位置(从 1 开始计数),没找到则返回 0。
注意:第二个参数是被搜索的字符串,第一个参数才是要找的字符或子串 —— 这和很多语言的函数顺序相反,容易写反。
-
LOCATE('a', 'banana')→ 返回2(不是 1) -
LOCATE('x', 'hello')→ 返回0,不是NULL,判断时别用IS NULL - 支持第三个参数指定起始搜索位置:
LOCATE('a', 'banana', 3)→ 返回4
PostgreSQL 中用 POSITION() 或 STRPOS()
PostgreSQL 提供两个等效函数:POSITION() 符合 SQL 标准,STRPOS() 是 PostgreSQL 自带的别名,行为一致,都返回从 1 开始的位置,未找到返回 0。
-
POSITION('o' IN 'hello')→ 返回5;注意语法是POSITION(sub IN str),中间用IN关键字 -
STRPOS('hello', 'l')→ 返回3;参数顺序和 MySQL 的LOCATE()一样 - 两者都不支持指定起始偏移,如需跳过前 N 个字符,得先用
SUBSTRING()截取再查
SQL Server 中用 CHARINDEX()
CHARINDEX() 是 SQL Server 的标准方案,返回从 1 开始的位置,找不到返回 0。它支持可选的第三个参数表示起始搜索位置。
-
CHARINDEX('e', 'hello')→ 返回2 -
CHARINDEX('l', 'hello', 3)→ 返回4(从第 3 位开始找,跳过了第一个l) - 区分大小写取决于数据库排序规则(collation),如果需要忽略大小写,确保列或字符串使用不区分大小写的 collation,比如加
COLLATE SQL_Latin1_General_CP1_CI_AS
跨数据库兼容性问题与常见误判
所有主流数据库都用“从 1 开始”而非“从 0 开始”,这点和编程语言习惯不同,直接参与计算(比如切片)前务必减 1;另外,返回值为 0 表示未找到,不是错误,所以 WHERE CHARINDEX(...) > 0 才是正确过滤写法。
- 不要把
LOCATE()和FIND_IN_SET()混用:FIND_IN_SET()只适用于逗号分隔的字符串列表,且只匹配完整项 - 想查所有出现位置?SQL 标准不支持正则全局匹配索引,MySQL 8.0+ 可用
REGEXP_SUBSTR()配合变量模拟,但性能差;更现实的做法是导出后用程序处理 - 在
ORDER BY或GROUP BY中使用这些函数时,注意它们不可索引,可能触发全表扫描
SELECT 试一两条数据,看返回值是不是你预期的“从 1 开始”的整数 —— 很多人卡在以为返回的是 0 起始,结果切串偏了。
相关文章
- 电子商务平台类型与主流模式解析 - 2026最新分类指南 06-22
- Iconfont图标库使用教程 - 2026最新入门指南 06-22
- 网店客服工作内容与技能要求 - 2026最新实用指南 06-22
- 米家智能家电官方选购平台 - 2026最新款全屋智能解决方案 06-22
- 2026年了 - 还在用过时的网络用语吗 06-22
- 共享充电宝租赁服务 - 便捷随借随还的移动电源 06-22