SAP HANA SQL系列五:字符串函数
ASCII
- ASCII©
- 返回字符串 c 中第一个字节的 ASCII 值。
SELECT ASCII('Ant') "ascii" FROM DUMMY;
ascii 65
CHAR
- CHAR (n)
- 返回 ASCII 值为数字 n 的字符。
SELECT CHAR (65) || CHAR (110) || CHAR (116) "character" FROM DUMMY;
character
Ant
CONCAT
- CONCAT (str1, str2)
- 返回位于 str1 后的 str2 联合组成的字符串。级联操作符(||)与该函数作用相同。
SELECT CONCAT ('C', 'at') "concat" FROM DUMMY;
1 2 | concat Cat |
LCASE
- LCASE(str)
- 将字符串 str 中所有字符转换为小写。
- 注意:LCASE 函数作用与 LOWER 函数相同。
SELECT LCASE ('TesT') "lcase" FROM DUMMY;
1 2 | lcase test |
LEFT
- LEFT (str, n)
- 返回字符串 str 开头 n 个字符/位的字符。
SELECT LEFT ('Hello', 3) "left" FROM DUMMY;
1 2 | left Hel |
LENGTH
- LENGTH(str)
- 返回字符串 str 中的字符数。对于大对象(LOB)类型,该函数返回对象的字节长度。
SELECT LENGTH ('length in char') "length" FROM DUMMY;
1 2 | length 14 |
LOCATE
- LOCATE (haystack, needle)
- 返回字符串 haystack 中子字符串 needle 所在的位置。如果未找到,则返回 0。
SELECT LOCATE ('length in char', 'char') "locate" FROM DUMMY;
Locate 11
SELECT LOCATE ('length in char', 'length') "locate" FROM DUMMY;
Locate 1
SELECT LOCATE ('length in char', 'zchar') "locate" FROM DUMMY;
Locate 0
LOWER
- LOWER (str)
- 将字符串 str 中所有字符转换为小写。
- 注意:LOWER 函数作用与 LCASE 相同。
SELECT LOWER ('AnT') "lower" FROM DUMMY;
1 2 | lower ant |
LPAD
- LPAD (str, n [, pattern])
- 从左边开始对字符串 str 使用空格进行填充,达到 n 指定的长度。如果指定了 pattern 参数,字符串 str 将按顺序填充直到满足 n 指定的长度。
SELECT LPAD ('end', 15, '12345') "lpad" FROM DUMMY;
1 2 | lpad 123451234512end |
LTRIM
- LTRIM (str [, remove_set])
- 返回字符串 str 截取所有前导空格后的值。如果定义了 remove_set,LTRIM 从起始位置移除字符串str 包含该集合中的字符,该过程持续至到达不在 remove_set 中的字符。
- 注意:remove_set 被视为字符集合,而非搜索字符。
SELECT LTRIM ('babababAabend','ab') "ltrim" FROM DUMMY;
1 2 | ltrim Aabend |
NCHAR
- NCHAR (n)
- 返回整数 n 表示的 Unicode 字符。
SELECT NCHAR (65) "nchar" FROM DUMMY;
1 | nchar <br>A |
REPLACE
- REPLACE (original_string, search_string, replace_string)
- 搜索 original_string 所有出现的 search_string,并用 replace_string 替换。
- 如果 original_string 为空, 则返回值也为空。
- 如果 original_string 中两个重叠的子字符串与 search_string 匹配,只有第一个会被替换。
- 如果 original_string 未出现 search_string,则返回未修改的 original_string。
- 如果 original_string,search_string 或者 replace_string 为 NULL,则返回值也为 NULL。
SELECT REPLACE ('DOWNGRADE DOWNWARD','DOWN', 'UP') "replace" FROM DUMMY;
1 2 | replace UPGRADE UPWARD |
RIGHT
- RIGHT(str, n)
- 返回字符串 str 中最右边的 n 字符/字节。
SELECT RIGHT('HI0123456789', 3) "right" FROM DUMMY;
1 2 | right 789 |
RPAD
- RPAD (str, n [, pattern])
- 从尾部开始对字符串 str 使用空格进行填充,达到 n 指定的长度。如果指定了 pattern 参数,字符串 str 将按顺序填充直到满足 n 指定的长度。
SELECT RPAD ('end', 15, '12345') "right padded" FROM DUMMY;
1 2 | right padded end123451234512 |
RTRIM
- RTRIM (str [,remove_set ])
- 返回字符串 str 截取所有后置空格后的值。如果定义了 remove_set,RTRIM 从尾部位置移除字符串 str 包含该集合中的字符,该过程持续至到达不在 remove_set 中的字符。
- 注意:remove_set 被视为字符集合,而非搜索字符。
SELECT RTRIM ('endabAabbabab','ab') "rtrim" FROM DUMMY;
1 2 | rtrim endabA |
SUBSTR_AFTER
- SUBSTR_AFTER (str, pattern)
- 返回 str 中位于 pattern 第一次出现位置后的子字符串。
- 如果 str 不包含 pattern 子字符串,则返回空字符串。
- 如果 pattern 为空字符串,则返回 str。
- 如果 str 或者 pattern 为 NULL,则返回 NULL。
SELECT SUBSTR_AFTER ('Hello My Friend','My ') "substr after" FROM DUMMY;
1 2 | substr after Friend |
SUBSTR_BEFORE
- SUBSTR_BEFORE (str, pattern)
- 返回 str 中位于 pattern 第一次出现位置前的子字符串。
- 如果 str 不包含 pattern 子字符串,则返回空字符串。
- 如果 pattern 为空字符串,则返回 str。
- 如果 str 或者 pattern 为 NULL,则返回 NULL。
SELECT SUBSTR_BEFORE ('Hello My Friend','My') "substr before" FROM DUMMY;
1 2 | substr before Hello |
SUBSTRING
- SUBSTRING (str, start_position [, string_length])
- 返回字符串 str 从 start_position 开始的子字符串。SUBSTRING 可以返回 start_position 起的剩余部分字符或者作为可选,返回由 string_length 参数设置的字符数。
- 如果 start_position 小于 0,则被视为 1。
- 如果 string_length 小于 1,则返回空字符串。
SELECT SUBSTRING ('1234567890',4,2) "substring" FROM DUMMY;
1 2 | substring 45 |
TRIM
- TRIM ([[LEADING | TRAILING | BOTH] trim_char FROM] str )
返回移除前导和后置空格后的字符串 str。截断操作从起始(LEADING)、结尾(TRAILING)或者两端(BOTH)执行。 - 如果 str 或者 trim_char 为空,则返回 NULL。
- 如果没有指定可选项,TRIM 移除字符串 str 中两端的子字符串 trim_char。
- 如果没有指定 trim_char,则使用单个空格。
SELECT TRIM ('a' FROM 'aaa123456789aa') "trim both" FROM DUMMY;
1 2 | trim both 123456789 |
SELECT TRIM (LEADING 'a' FROM 'aaa123456789aa') "trim leading" FROM DUMMY;
1 2 | trim leading 123456789aa |
UCASE
- UCASE (str)
- 将字符串 str 中所有字符转换为大写。
- 注意:UCASE 函数作用与 UPPER 函数相同。
SELECT UCASE ('Ant') "ucase" FROM DUMMY;
1 2 | ucase ANT |
UNICODE
- UNICODE©
- 返回字符串中首字母的 UnIcode 字符码数字;如果首字母不是有效编码,则返回 NULL。
SELECT UNICODE ('#') "unicode" FROM DUMMY;
1 2 | unicode 35 |
UPPER
- UPPER (str)
- 将字符串 str 中所有字符转换为大写。
- 注意:UPPER 函数作用与 UCASE 相同。
SELECT UPPER ('Ant') "uppercase" FROM DUMMY;
1 2 | uppercase ANT |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix