Amazon Redshift
数据库开发人员指南 (API Version 2012-12-01)
AWS 服务或AWS文档中描述的功能,可能因地区/位置而异。请点击 Amazon AWS 入门,可查看中国地区的具体差异

SUBSTRING 函数

基于指定数量的字符的指定字符位置返回从字符串中提取的字符。

字符的字符位置和数量基于字符数而不是字节数,这是为了将多字节字符作为单个字符计数。您无法指定负长度,但您可指定负开始位置。

语法

Copy
SUBSTRING(string FROM start_position [ FOR number_characters ] )
Copy
SUBSTRING(string, start_position, number_characters )

参数

string

要搜索的字符串。非字符数据类型将视为字符串。

start_position

字符串中开始提取的位置,从 1 开始。start_position 基于字符数而不是字节数,这是为了将多字节字符作为单个字符计数。此数字可以为负。

number_characters

要提取的字符的数量(子字符串的长度)。number_characters 基于字符数而不是字节数,这是为了将多字节字符作为单个字符计数。此数字不能为负。

返回类型

VARCHAR

使用说明

以下示例返回以第 6 个字符开头的 4 字符字符串。

Copy
select substring('caterpillar',6,4); substring ----------- pill (1 row)

如果 start_position + number_characters 超过 string 的长度,SUBSTRING 将返回从 start_position 开始到此字符串的末尾的子字符串。例如:

Copy
select substring('caterpillar',6,8); substring ----------- pillar (1 row)

如果 start_position 为负或 0,SUBSTRING 函数将返回从长度为 start_position + number_characters -1 的字符串的第一个字符开始的子字符串。例如:

Copy
select substring('caterpillar',-2,6); substring ----------- cat (1 row)

如果 start_position + number_characters -1 小于或等于零,SUBSTRING 将返回空字符串。例如:

Copy
select substring('caterpillar',-5,4); substring ----------- (1 row)

示例

以下示例返回 LISTING 表的 LISTTIME 字符串中的月份:

Copy
select listid, listtime, substring(listtime, 6, 2) as month from listing order by 1, 2, 3 limit 10; listid | listtime | month --------+---------------------+------- 1 | 2008-01-24 06:43:29 | 01 2 | 2008-03-05 12:25:29 | 03 3 | 2008-11-01 07:35:33 | 11 4 | 2008-05-24 01:18:37 | 05 5 | 2008-05-17 02:29:11 | 05 6 | 2008-08-15 02:08:13 | 08 7 | 2008-11-15 09:38:15 | 11 8 | 2008-11-09 05:07:30 | 11 9 | 2008-09-09 08:03:36 | 09 10 | 2008-06-17 09:44:54 | 06 (10 rows)

以下示例与上述示例相同,但使用 FROM...FOR 选项:

Copy
select listid, listtime, substring(listtime from 6 for 2) as month from listing order by 1, 2, 3 limit 10; listid | listtime | month --------+---------------------+------- 1 | 2008-01-24 06:43:29 | 01 2 | 2008-03-05 12:25:29 | 03 3 | 2008-11-01 07:35:33 | 11 4 | 2008-05-24 01:18:37 | 05 5 | 2008-05-17 02:29:11 | 05 6 | 2008-08-15 02:08:13 | 08 7 | 2008-11-15 09:38:15 | 11 8 | 2008-11-09 05:07:30 | 11 9 | 2008-09-09 08:03:36 | 09 10 | 2008-06-17 09:44:54 | 06 (10 rows)

您无法使用 SUBSTRING 以可预测的方式提取可能包含多字节字符的字符串的前缀,因为您需要根据字节数(而不是字符数)指定多字节字符串的长度。要基于以字节为单位的长度提取字符串的开始部分,您可将字符串强制转换为 VARCHAR(byte_length) 以截断字符串,其中 byte_length 是必需长度。以下示例提取字符串 'Fourscore and seven' 的前 5 个字节。

Copy
select cast('Fourscore and seven' as varchar(5)); varchar ------- Fours