SAP HANA SQL系列五:字串函式
阿新 • • 發佈:2022-12-05
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 聯合組成的字串。級聯操作符(||)與該函式作用相同。
SELECTCONCAT ('C', 'at') "concat" FROM DUMMY;
concat Cat
LCASE
- LCASE(str)
- 將字串 str 中所有字元轉換為小寫。
- 注意:LCASE 函式作用與 LOWER 函式相同。
SELECT LCASE ('TesT') "lcase" FROM DUMMY;
lcase test
LEFT
- LEFT (str, n)
- 返回字串 str 開頭 n 個字元/位的字元。
SELECT LEFT ('Hello', 3) "left" FROM DUMMY;
left Hel
LENGTH
- LENGTH(str)
- 返回字串 str 中的字元數。對於大物件(LOB)型別,該函式返回物件的位元組長度。
SELECT LENGTH ('length in char') "length" FROM DUMMY;
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;
lower ant
LPAD
- LPAD (str, n [, pattern])
- 從左邊開始對字串 str 使用空格進行填充,達到 n 指定的長度。如果指定了 pattern 引數,字串 str 將按順序填充直到滿足 n 指定的長度。
SELECT LPAD ('end', 15, '12345') "lpad" FROM DUMMY;
lpad 123451234512end
LTRIM
- LTRIM (str [, remove_set])
- 返回字串 str 擷取所有前導空格後的值。如果定義了 remove_set,LTRIM 從起始位置移除字串str 包含該集合中的字元,該過程持續至到達不在 remove_set 中的字元。
- 注意:remove_set 被視為字元集合,而非搜尋字元。
SELECT LTRIM ('babababAabend','ab') "ltrim" FROM DUMMY;
ltrim Aabend
NCHAR
- NCHAR (n)
- 返回整數 n 表示的 Unicode 字元。
SELECT NCHAR (65) "nchar" FROM DUMMY;
nchar
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;
replace UPGRADE UPWARD
RIGHT
- RIGHT(str, n)
- 返回字串 str 中最右邊的 n 字元/位元組。
SELECT RIGHT('HI0123456789', 3) "right" FROM DUMMY;
right 789
RPAD
- RPAD (str, n [, pattern])
- 從尾部開始對字串 str 使用空格進行填充,達到 n 指定的長度。如果指定了 pattern 引數,字串 str 將按順序填充直到滿足 n 指定的長度。
SELECT RPAD ('end', 15, '12345') "right padded" FROM DUMMY;
right padded end123451234512
RTRIM
- RTRIM (str [,remove_set ])
- 返回字串 str 擷取所有後置空格後的值。如果定義了 remove_set,RTRIM 從尾部位置移除字串 str 包含該集合中的字元,該過程持續至到達不在 remove_set 中的字元。
- 注意:remove_set 被視為字元集合,而非搜尋字元。
SELECT RTRIM ('endabAabbabab','ab') "rtrim" FROM DUMMY;
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;
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;
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;
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;
trim both 123456789
SELECT TRIM (LEADING 'a' FROM 'aaa123456789aa') "trim leading" FROM DUMMY;
trim leading 123456789aa
UCASE
- UCASE (str)
- 將字串 str 中所有字元轉換為大寫。
- 注意:UCASE 函式作用與 UPPER 函式相同。
SELECT UCASE ('Ant') "ucase" FROM DUMMY;
ucase ANT
UNICODE
- UNICODE©
- 返回字串中首字母的 UnIcode 字元碼數字;如果首字母不是有效編碼,則返回 NULL。
SELECT UNICODE ('#') "unicode" FROM DUMMY;
unicode 35
UPPER
- UPPER (str)
- 將字串 str 中所有字元轉換為大寫。
- 注意:UPPER 函式作用與 UCASE 相同。
SELECT UPPER ('Ant') "uppercase" FROM DUMMY;
uppercase ANT