1. 程式人生 > 其它 >SAP HANA SQL系列五:字串函式

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;
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