日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

hive常用函数之七字符串函数

發(fā)布時(shí)間:2024/3/12 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hive常用函数之七字符串函数 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

七、字符串函數(shù)

1. 字符串長度函數(shù):length

語法: length(string A)

返回值: int

說明:返回字符串A的長度

舉例:

hive> select length(‘a(chǎn)bcedfg’) from lxw_dual;

7

2. 字符串反轉(zhuǎn)函數(shù):reverse

語法: reverse(string A)

返回值: string

說明:返回字符串A的反轉(zhuǎn)結(jié)果

舉例:

hive> select reverse(abcedfg’) from lxw_dual;

gfdecba

3. 字符串連接函數(shù):concat

語法: concat(string A, string B…)

返回值: string

說明:返回輸入字符串連接后的結(jié)果,支持任意個(gè)輸入字符串

舉例:

hive> select concat(‘a(chǎn)bc’,'def’,'gh’) from lxw_dual;

abcdefgh

4. 帶分隔符字符串連接函數(shù):concat_ws

語法: concat_ws(string SEP, string A, string B…)

返回值: string

說明:返回輸入字符串連接后的結(jié)果,SEP表示各個(gè)字符串間的分隔符

舉例:

hive> select concat_ws(’,’,‘a(chǎn)bc’,‘def’,‘gh’) from lxw_dual;

abc,def,gh

5. 字符串截取函數(shù):substr,substring

語法: substr(string A, int start),substring(string A, int start)

返回值: string

說明:返回字符串A從start位置到結(jié)尾的字符串

舉例:

hive> select substr(‘a(chǎn)bcde’,3) from lxw_dual;

cde

hive> select substring(‘a(chǎn)bcde’,3) from lxw_dual;

cde

hive> selectsubstr(‘a(chǎn)bcde’,-1) from lxw_dual; (和ORACLE相同)

e

6. 字符串截取函數(shù):substr,substring

語法: substr(string A, int start, int len),substring(string A, intstart, int len)

返回值: string

說明:返回字符串A從start位置開始,長度為len的字符串

舉例:

hive> select substr(‘a(chǎn)bcde’,3,2) from lxw_dual;

cd

hive> select substring(‘a(chǎn)bcde’,3,2) from lxw_dual;

cd

hive>select substring(‘a(chǎn)bcde’,-2,2) from lxw_dual;

de

7. 字符串轉(zhuǎn)大寫函數(shù):upper,ucase

語法: upper(string A) ucase(string A)

返回值: string

說明:返回字符串A的大寫格式

舉例:

hive> select upper(‘a(chǎn)bSEd’) from lxw_dual;

hive> select ucase(‘a(chǎn)bSEd’) from lxw_dual;

8. 字符串轉(zhuǎn)小寫函數(shù):lower,lcase

語法: lower(string A) lcase(string A)

返回值: string

說明:返回字符串A的小寫格式

舉例:

hive> select lower(‘a(chǎn)bSEd’) from lxw_dual;

absed

hive> select lcase(‘a(chǎn)bSEd’) from lxw_dual;

absed

9. 去空格函數(shù):trim

語法: trim(string A)

返回值: string

說明:去除字符串兩邊的空格

舉例:

hive> select trim(’ abc ') from lxw_dual;

abc

10. 左邊去空格函數(shù):ltrim

語法: ltrim(string A)

返回值: string

說明:去除字符串左邊的空格

舉例:

hive> select ltrim(’ abc ') from lxw_dual;

abc

11. 右邊去空格函數(shù):rtrim

語法: rtrim(string A)

返回值: string

說明:去除字符串右邊的空格

舉例:

hive> select rtrim(’ abc ') from lxw_dual;

abc

12. 正則表達(dá)式替換函數(shù):regexp_replace

語法: regexp_replace(string A, string B, string C)

返回值: string

說明:將字符串A中的符合java正則表達(dá)式B的部分替換為C。注意,在有些情況下要使用轉(zhuǎn)義字符,類似oracle中的regexp_replace函數(shù)。

舉例:

hive> select regexp_replace(‘foobar’, ‘oo|ar’, ‘’) from lxw_dual;

fb

13. 正則表達(dá)式解析函數(shù):regexp_extract

語法: regexp_extract(string subject, string pattern, int index)

返回值: string

說明:將字符串subject按照pattern正則表達(dá)式的規(guī)則拆分,返回index指定的字符。

舉例:

hive> select regexp_extract(‘foothebar’, ‘foo(.*?)(bar)’, 1) fromlxw_dual;

the

hive> select regexp_extract(‘foothebar’, ‘foo(.*?)(bar)’, 2) fromlxw_dual;

bar

hive> select regexp_extract(‘foothebar’, ‘foo(.*?)(bar)’, 0) fromlxw_dual;

foothebar

注意,在有些情況下要使用轉(zhuǎn)義字符,下面的等號(hào)要用雙豎線轉(zhuǎn)義,這是java正則表達(dá)式的規(guī)則。

select data_field,

regexp_extract(data_field,'.*?bgStart\\=([^&]+)',1) as aaa,regexp_extract(data_field,'.*?contentLoaded_headStart\\=([^&]+)',1) as bbb,regexp_extract(data_field,'.*?AppLoad2Req\\=([^&]+)',1) as cccfrom pt_nginx_loginlog_stwhere pt = '2012-03-26'limit 2;

14. URL解析函數(shù):parse_url

語法: parse_url(string urlString, string partToExtract [, stringkeyToExtract])

返回值: string

說明:返回URL中指定的部分。partToExtract的有效值為:HOST, PATH, QUERY, REF, PROTOCOL, AUTHORITY, FILE, and USERINFO.

舉例:

hive> selectparse_url(‘http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1’, ‘HOST’) fromlxw_dual;

facebook.com

hive> selectparse_url(‘http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1’, ‘QUERY’,‘k1’) from lxw_dual;

v1

15. json解析函數(shù):get_json_object

語法: get_json_object(string json_string, string path)

返回值: string

說明:解析json的字符串json_string,返回path指定的內(nèi)容。如果輸入的json字符串無效,那么返回NULL。

舉例:

hive> select get_json_object(’{“store”:

{“fruit”:[{“weight”:8,“type”:“apple”},{“weight”:9,“type”:“pear”}],

“bicycle”:{“price”:19.95,“color”:“red”}

},

“email”:“amy@only_for_json_udf_test.net”,

“owner”:“amy”

}

‘,’$.owner’) from lxw_dual;

amy

16. 空格字符串函數(shù):space

語法: space(int n)

返回值: string

說明:返回長度為n的字符串

舉例:

hive> select space(10) from lxw_dual;

hive> select length(space(10)) from lxw_dual;

10

17. 重復(fù)字符串函數(shù):repeat

語法: repeat(string str, int n)

返回值: string

說明:返回重復(fù)n次后的str字符串

舉例:

hive> select repeat(‘a(chǎn)bc’,5) from lxw_dual;

abcabcabcabcabc

18. 首字符ascii函數(shù):ascii

語法: ascii(string str)

返回值: int

說明:返回字符串str第一個(gè)字符的ascii碼

舉例:

hive> select ascii(‘a(chǎn)bcde’) from lxw_dual;

97

19. 左補(bǔ)足函數(shù):lpad

語法: lpad(string str, int len, string pad)

返回值: string

說明:將str進(jìn)行用pad進(jìn)行左補(bǔ)足到len位

舉例:

hive> select lpad(‘a(chǎn)bc’,10,‘td’) from lxw_dual;

tdtdtdtabc

注意:與GP,ORACLE不同,pad不能默認(rèn)

20. 右補(bǔ)足函數(shù):rpad

語法: rpad(string str, int len, string pad)

返回值: string

說明:將str進(jìn)行用pad進(jìn)行右補(bǔ)足到len位

舉例:

hive> select rpad(‘a(chǎn)bc’,10,‘td’) from lxw_dual;

abctdtdtdt

21. 分割字符串函數(shù): split

語法: split(string str, stringpat)

返回值: array

說明:按照pat字符串分割str,會(huì)返回分割后的字符串?dāng)?shù)組

舉例:

hive> select split(‘a(chǎn)btcdtef’,‘t’) from lxw_dual;

[“ab”,“cd”,“ef”]

22. 集合查找函數(shù):find_in_set

語法: find_in_set(string str, string strList)

返回值: int

說明:返回str在strlist第一次出現(xiàn)的位置,strlist是用逗號(hào)分割的字符串。如果沒有找該str字符,則返回0

舉例:

hive> select find_in_set(‘a(chǎn)b’,‘ef,ab,de’) from lxw_dual;

2

hive> select find_in_set(‘a(chǎn)t’,‘ef,ab,de’) from lxw_dual;

0

總結(jié)

以上是生活随笔為你收集整理的hive常用函数之七字符串函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。