答案:SQL中提取字符主要使用SUBSTRING/SUBSTR、CHARINDEX/INSTR、LEFT、RIGHT等函数,结合LEN计算长度,根据不同数据库语法差异定位并截取目标字符串。

在 SQL 中提取特定字符或子字符串,主要依赖字符串函数。不同数据库(如 MySQL、SQL Server、Oracle)语法略有差异,但核心函数类似。以下是常用方法和示例,帮助你精准提取所需字符。
1. SUBSTRING / SUBSTR 函数
用于从字符串中提取指定位置开始的一定长度的字符。
MySQL / PostgreSQL / Oracle:
使用 SUBSTR(string, start_position, length)例如,提取 "HelloWorld" 中第6个字符开始的5个字符:
SUBSTR('HelloWorld', 6, 5) → 'World'SQL Server:
使用 SUBSTRING(string, start, length)SUBSTRING('HelloWorld', 6, 5) → 'World'注意:起始位置通常从1开始,不是0。
2. 使用 CHARINDEX / INSTR 定位字符
若要提取某个特定字符或子串后的内容,需先找到它的位置。
MySQL / Oracle:
INSTR(string, substring) 返回子串首次出现的位置INSTR('user@example.com', '@') → 5SQL Server:
CHARINDEX('@', 'user@example.com') → 5结合使用可提取 @ 后的域名:
SUBSTRING(email, CHARINDEX('@', email) + 1, LEN(email))结果为:example.com
3. 提取分隔符之间的内容
常见于提取 CSV 字段或路径中的文件名。
例如,提取路径 'C:\Users\John\file.txt' 中的文件名:
-- 找最后一个反斜杠位置CHARINDEX('\', REVERSE(path)) 得到倒数位置再用 SUBSTRING 截取简化写法(以 SQL Server 为例):
SUBSTRING(path, LEN(path) - CHARINDEX('\', REVERSE(path)) + 2, LEN(path))得到:file.txt
4. LEFT、RIGHT 和 LEN 辅助提取
从字符串开头或结尾提取固定长度字符。
LEFT('ABC123', 3) → 'ABC'RIGHT('ABC123', 3) → '123'LEN('ABC123') → 6(用于计算长度)例如,提取手机号前3位:
LEFT(phone, 3)基本上就这些常用方式。根据你要提取的字符位置和规则,组合使用定位和截取函数即可。注意不同数据库的函数名称差异,比如 MySQL 用 LENGTH(),而 SQL Server 用 LEN()。










