日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Hive常用函数大全(一)(关系/数学/逻辑/数值/日期/条件/字符串/集合统计/复杂类型)

發(fā)布時間:2023/12/16 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Hive常用函数大全(一)(关系/数学/逻辑/数值/日期/条件/字符串/集合统计/复杂类型) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

https://blog.csdn.net/scgaliguodong123_/article/details/60881166

?

測試數(shù)據(jù)集:

create external table if not exists order_detail( user_id string, device_id string, user_type string, price double, sales int ) row format delimited fields terminated by '\t' lines terminated by '\n' stored as textfile;hdfs dfs -put /home/liguodong/data/data.text /temp/lgdload data inpath '/temp/lgd/data.text' overwrite into table order_detail;select * from order_detail; +----------+-------------+------------+--------+--------+--+ | user_id | device_id | user_type | price | sales | +----------+-------------+------------+--------+--------+--+ | zhangsa | dfsadsa323 | new | 67.1 | 2 | | lisi | 543gfd | old | 43.32 | 1 | | wanger | 65ghf | new | 88.88 | 3 | | liiu | fdsfagwe | new | 66.0 | 1 | | qibaqiu | fds | new | 54.32 | 1 | | wangshi | f332 | old | 77.77 | 2 | | liwei | hfd | old | 88.44 | 3 | | wutong | 543gdfsd | new | 56.55 | 6 | | lilisi | dsfgg | new | 88.88 | 5 | | qishili | fds | new | 66.66 | 5 | +----------+-------------+------------+--------+--------+--+
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30

關(guān)系運(yùn)算

## > < = ##注意: String 的比較要注意(常用的時間比較可以先 to_date 之后再比較) select long_time>short_time, long_time<short_time,long_time=short_time, to_date(long_time)=to_date(short_time) from (select '2017-01-11 00:00:00' as long_time, '2017-01-11' as short_timefrom order_detail limit 1 )bb;result: true false false true## 空值判斷 select 1 from order_detail where NULL is NULL limit 1;## 非空判斷 select 1 from order_detail where 1 is not NULL limit 1;## LIKE 語法: A LIKE B 描述: 字符串A符合表達(dá)式B的正則語法,則為TRUE;否則為FALSE. B中字符”_”表示任意單個字符,而字符”%”表示任意數(shù)量的字符。select user_id from order_detail where user_id like 'li%';+----------+--+ | user_id | +----------+--+ | lisi | | liiu | | liwei | | lilisi | +----------+--+select user_id from order_detail where user_id like 'li__';+----------+--+ | user_id | +----------+--+ | lisi | | liiu | +----------+--+## RLIKE 語法: A RLIKE B 描述: 字符串A符合JAVA正則表達(dá)式 B 的正則語法,則為 TRUE;否則為 FALSE。select user_id from order_detail where user_id rlike '^l.*i$';+----------+--+ | user_id | +----------+--+ | lisi | | liwei | | lilisi | +----------+--+select device_id from order_detail where device_id rlike '^\\w+$';+-------------+--+ | device_id | +-------------+--+ | dfsadsa323 | | 543gfd | | 65ghf | | fdsfagwe | | fds | | f332 | | hfd | | 543gdfsd | | dsfgg | | fds | +-------------+--+select device_id from order_detail where device_id rlike '^[a-zA-Z]+$';+------------+--+ | device_id | +------------+--+ | fdsfagwe | | fds | | hfd | | dsfgg | | fds | +------------+--+select device_id from order_detail where device_id rlike '^[a-zA-Z]{4,}$';+------------+--+ | device_id | +------------+--+ | fdsfagwe | | dsfgg | +------------+--+## REGEXP 語法: A REGEXP B 描述: 功能與 RLIKE 相同 select device_id from order_detail where device_id REGEXP '^[a-zA-Z]{4,}$';+------------+--+ | device_id | +------------+--+ | fdsfagwe | | dsfgg | +------------+--+
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110

數(shù)學(xué)運(yùn)算

## + - * / 注意: hive中最高精度的數(shù)據(jù)類型是 double,只精確到小數(shù)點(diǎn)后16位,在做除法運(yùn)算的時候要特別注意select user_id,100-price,sales-1,price*sales,price/sales, ceil(28.0/6.999999999999999999999),ceil(28.0/6.99999999999999), price%sales from order_detail;+----------+---------------------+------+---------------------+---------------------+------+------+---------------------+--+ | user_id | _c1 | _c2 | _c3 | _c4 | _c5 | _c6 | _c7 | +----------+---------------------+------+---------------------+---------------------+------+------+---------------------+--+ | zhangsa | 32.900000000000006 | 1 | 134.2 | 33.55 | 4 | 5 | 1.0999999999999943 | | lisi | 56.68 | 0 | 43.32 | 43.32 | 4 | 5 | 0.3200000000000003 | | wanger | 11.120000000000005 | 2 | 266.64 | 29.626666666666665 | 4 | 5 | 1.8799999999999955 | | liiu | 34.0 | 0 | 66.0 | 66.0 | 4 | 5 | 0.0 | | qibaqiu | 45.68 | 0 | 54.32 | 54.32 | 4 | 5 | 0.3200000000000003 | | wangshi | 22.230000000000004 | 1 | 155.54 | 38.885 | 4 | 5 | 1.769999999999996 | | liwei | 11.560000000000002 | 2 | 265.32 | 29.48 | 4 | 5 | 1.4399999999999977 | | wutong | 43.45 | 5 | 339.29999999999995 | 9.424999999999999 | 4 | 5 | 2.549999999999997 | | lilisi | 11.120000000000005 | 4 | 444.4 | 17.776 | 4 | 5 | 3.8799999999999955 | | qishili | 33.34 | 4 | 333.29999999999995 | 13.331999999999999 | 4 | 5 | 1.6599999999999966 | +----------+---------------------+------+---------------------+---------------------+------+------+---------------------+--+## % 注意: 精度在 hive 中是個很大的問題,類似這樣的操作最好通過 round 指定精度 select 8.4 % 4,round(8.4 % 4 , 2) from order_detail limit 1;+----------------------+------+--+ | _c0 | _c1 | +----------------------+------+--+ | 0.40000000000000036 | 0.4 | +----------------------+------+--+## 位與& 位或| 位異或^ 位取反~select 4&6, 8&4, 4|8,6|8,4^8,6^4,~6,~3 from order_detail limit 1;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39

邏輯運(yùn)算

## 邏輯與AND 邏輯或OR 邏輯非NOT 注意:優(yōu)先級一次為NOT AND OR## 以下兩條SQL互斥 select user_id from order_detail where not ((user_id='wanger' or user_id like 'li%') and user_type='old');+----------+--+ | user_id | +----------+--+ | zhangsa | | wanger | | liiu | | qibaqiu | | wangshi | | wutong | | lilisi | | qishili | +----------+--+select user_id from order_detail where ((user_id='wanger' or user_id like 'li%') and user_type='old');+----------+--+ | user_id | +----------+--+ | lisi | | liwei | +----------+--+
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

數(shù)值計(jì)算函數(shù)

## 取整: round 語法: round(double a) 說明: 遵循四舍五入## 指定精度取整: round 語法: round(double a, int d)## 向下取整: floor 說明: 返回等于或者小于該 double 變量的最大的整數(shù)## 向上取整: ceil 說明: 返回等于或者大于該 double 變量的最小的整數(shù)## 向上取整: ceiling 說明: 與ceil功能相同select user_id,price,round(price),round(price,0),round(price,1),floor(price),ceil(price),ceiling(price) from order_detail;+----------+--------+-------+-------+-------+------+------+------+--+ | user_id | price | _c2 | _c3 | _c4 | _c5 | _c6 | _c7 | +----------+--------+-------+-------+-------+------+------+------+--+ | zhangsa | 67.1 | 67.0 | 67.0 | 67.1 | 67 | 68 | 68 | | lisi | 43.32 | 43.0 | 43.0 | 43.3 | 43 | 44 | 44 | | wanger | 88.88 | 89.0 | 89.0 | 88.9 | 88 | 89 | 89 | | liiu | 66.0 | 66.0 | 66.0 | 66.0 | 66 | 66 | 66 | | qibaqiu | 54.32 | 54.0 | 54.0 | 54.3 | 54 | 55 | 55 | | wangshi | 77.77 | 78.0 | 78.0 | 77.8 | 77 | 78 | 78 | | liwei | 88.44 | 88.0 | 88.0 | 88.4 | 88 | 89 | 89 | | wutong | 56.55 | 57.0 | 57.0 | 56.6 | 56 | 57 | 57 | | lilisi | 88.88 | 89.0 | 89.0 | 88.9 | 88 | 89 | 89 | | qishili | 66.66 | 67.0 | 67.0 | 66.7 | 66 | 67 | 67 | +----------+--------+-------+-------+-------+------+------+------+--+## 取隨機(jī)數(shù): rand 說明: 返回一個 0 到 1 范圍內(nèi)的隨機(jī)數(shù)。如果指定種子 seed(整數(shù)),則會得到一個穩(wěn)定的隨機(jī)數(shù)序列。## 自然指數(shù): exp 自然對數(shù): lnselect user_id,sales,price,rand(),rand(sales),exp(sales),ln(price) from order_detail;+----------+--------+--------+----------------------+----------------------+---------------------+---------------------+--+ | user_id | sales | price | _c3 | _c4 | _c5 | _c6 | +----------+--------+--------+----------------------+----------------------+---------------------+---------------------+--+ | zhangsa | 2 | 67.1 | 0.708066911383928 | 0.7311469360199058 | 7.38905609893065 | 4.206184043977636 | | lisi | 1 | 43.32 | 0.509552420396184 | 0.9014476240300544 | 2.718281828459045 | 3.76861442213279 | | wanger | 3 | 88.88 | 0.2462642074705902 | 0.49682259343089075 | 20.085536923187668 | 4.487287145331375 | | liiu | 1 | 66.0 | 0.720800913818751 | 0.9858769332362016 | 2.718281828459045 | 4.189654742026425 | | qibaqiu | 1 | 54.32 | 0.7358273250797408 | 0.8571240443456863 | 2.718281828459045 | 3.9948924832504407 | | wangshi | 2 | 77.77 | 0.11092554405907218 | 0.9874208338984266 | 7.38905609893065 | 4.353755752706852 | | liwei | 3 | 88.44 | 0.5162574691353392 | 0.2281579303734177 | 20.085536923187668 | 4.482324355989245 | | wutong | 6 | 56.55 | 0.2753658209591686 | 0.07479382813444624 | 403.4287934927351 | 4.03512520256213 | | lilisi | 5 | 88.88 | 0.25777632824045826 | 0.7431577182910525 | 148.4131591025766 | 4.487287145331375 | | qishili | 5 | 66.66 | 0.06419187859857822 | 0.9495832704567262 | 148.4131591025766 | 4.199605072879594 | +----------+--------+--------+----------------------+----------------------+---------------------+---------------------+--+## 以10為底對數(shù): log10 以2為底對數(shù): log2 ## 對數(shù): log 語法: log(double base, double a) 說明: 返回以 base 為底的 a 的對數(shù)select log10(100),log2(8),log(4,256) from order_detail limit 1;+------+------+------+--+ | _c0 | _c1 | _c2 | +------+------+------+--+ | 2.0 | 3.0 | 4.0 | +------+------+------+--+## 冪運(yùn)算: pow power 開平方: sqrtselect pow(2,4), power(2,4),sqrt(16) from order_detail limit 1;+-------+-------+------+--+ | _c0 | _c1 | _c2 | +-------+-------+------+--+ | 16.0 | 16.0 | 4.0 | +-------+-------+------+--+## 二進(jìn)制: bin 十六進(jìn)制: hex 反轉(zhuǎn)十六進(jìn)制: unhex ## 進(jìn)制轉(zhuǎn)換: conv 語法: conv(BIGINT num, int from_base, int to_base) 說明: 將數(shù)值 num 從 from_base 進(jìn)制轉(zhuǎn)化到 to_base 進(jìn)制select bin(7),hex('19'),hex('abc'),unhex('616263'),unhex('41'),conv(17,10,16),conv(17,10,2) from order_detail limit 1;+------+-------+---------+------+------+------+--------+--+ | _c0 | _c1 | _c2 | _c3 | _c4 | _c5 | _c6 | +------+-------+---------+------+------+------+--------+--+ | 111 | 3139 | 616263 | abc | A | 11 | 10001 | +------+-------+---------+------+------+------+--------+--+## 絕對值:abs 正取余:pmod 正弦:sin 反正弦:asin 余弦:cos 反余弦:acos 返回A的值:positive 返回A的相反數(shù):negativeselect abs(-13),abs(10.10),pmod(9,4),pmod(-9,4), sin(0.8),asin(0.7173560908995228),cos(0.9), acos(0.6216099682706644), positive(-10),negative(-10) from order_detail limit 1;+------+-------+------+------+---------------------+------+---------------------+------+------+------+--+ | _c0 | _c1 | _c2 | _c3 | _c4 | _c5 | _c6 | _c7 | _c8 | _c9 | +------+-------+------+------+---------------------+------+---------------------+------+------+------+--+ | 13 | 10.1 | 1 | 3 | 0.7173560908995228 | 0.8 | 0.6216099682706644 | 0.9 | -10 | 10 | +------+-------+------+------+---------------------+------+---------------------+------+------+------+--+
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108

日期函數(shù)

## UNIX時間戳轉(zhuǎn)日期: from_unixtime## 日期轉(zhuǎn)UNIX時間戳,指定格式日期轉(zhuǎn)UNIX 時間戳,獲取當(dāng)前UNIX時間戳: unix_timestamp 說明: 轉(zhuǎn)換格式為"yyyy-MM-dd HH:mm:ss"的日期到 UNIX 時間戳。如果轉(zhuǎn)化失敗,則返回 0。select from_unixtime(1323308943),from_unixtime(1323308943,'yyyyMMdd'),unix_timestamp(),unix_timestamp('2017-12-07 16:01:03'),unix_timestamp('20171207 16-01-03','yyyyMMdd HH-mm-ss') from order_detail limit 1; +----------------------+-----------+-------------+-------------+-------------+--+ | _c0 | _c1 | _c2 | _c3 | _c4 | +----------------------+-----------+-------------+-------------+-------------+--+ | 2011-12-08 09:49:03 | 20111208 | 1489029488 | 1512633663 | 1512633663 | +----------------------+-----------+-------------+-------------+-------------+--+## 日期時間轉(zhuǎn)日期:to_date 日期轉(zhuǎn)年:year 日期轉(zhuǎn)月:month 日期轉(zhuǎn)天:day 日期轉(zhuǎn)小時:hour 日期轉(zhuǎn)分鐘:minute 日期轉(zhuǎn)秒:secondselect to_date('2016-12-08 10:03:01'), year('2016-12-08 10:03:01'), month('2016-12-08'), day('2016-12-08 10:03:01'), hour('2016-12-08 10:03:01'), minute('2016-12-08 10:03:01'), second('2016-12-08 10:03:01') from order_detail limit 1; +-------------+-------+------+------+------+------+------+--+ | _c0 | _c1 | _c2 | _c3 | _c4 | _c5 | _c6 | +-------------+-------+------+------+------+------+------+--+ | 2016-12-08 | 2016 | 12 | 8 | 10 | 3 | 1 | +-------------+-------+------+------+------+------+------+--+## 日期轉(zhuǎn)周:weekofyear 日期比較:datediff select weekofyear('2016-12-08 10:03:01'), datediff('2016-12-08','2016-11-27') from order_detail limit 1;+------+------+--+ | _c0 | _c1 | +------+------+--+ | 49 | 11 | +------+------+--+## 日期增加: date_add 日期減少: date_sub select date_add('2016-12-08',10),date_add('2016-12-08',-10), date_sub('2016-12-08',-10),date_sub('2016-12-08',10) from order_detail limit 1;+-------------+-------------+-------------+-------------+--+ | _c0 | _c1 | _c2 | _c3 | +-------------+-------------+-------------+-------------+--+ | 2016-12-18 | 2016-11-28 | 2016-12-18 | 2016-11-28 | +-------------+-------------+-------------+-------------+--+select date_add('20161208',10), from_unixtime(unix_timestamp(date_add('2016-12-08',10)),'yyyyMMdd'), from_unixtime(unix_timestamp(date_add('2016-12-08',10),'yyyy-MM-dd'),'yyyyMMdd') from order_detail limit 1;+-------+-------+-----------+--+ | _c0 | _c1 | _c2 | +-------+-------+-----------+--+ | NULL | NULL | 20161218 | +-------+-------+-----------+--+
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72

條件函數(shù)

## IF CASE COALESCE 說明: COALESCE返回參數(shù)中的第一個非空值;如果所有值都為 NULL,那么返回 NULLselect user_id,device_id,user_type,sales, if(user_type='new',user_id,'***'), COALESCE(null,user_id,device_id,user_type), COALESCE(null,null,device_id,user_type), case user_type when 'new' then 'new_user' when 'old' then 'old_user' else 'others' end, case when user_type='new' and sales>=5 then 'gold_user' when user_type='old' and sales<3 then 'bronze_user' else 'silver_user' end from order_detail;+----------+-------------+------------+--------+----------+----------+-------------+-----------+--------------+--+ | user_id | device_id | user_type | sales | _c4 | _c5 | _c6 | _c7 | _c8 | +----------+-------------+------------+--------+----------+----------+-------------+-----------+--------------+--+ | zhangsa | dfsadsa323 | new | 2 | zhangsa | zhangsa | dfsadsa323 | new_user | silver_user | | lisi | 543gfd | old | 1 | *** | lisi | 543gfd | old_user | bronze_user | | wanger | 65ghf | new | 3 | wanger | wanger | 65ghf | new_user | silver_user | | liiu | fdsfagwe | new | 1 | liiu | liiu | fdsfagwe | new_user | silver_user | | qibaqiu | fds | new | 1 | qibaqiu | qibaqiu | fds | new_user | silver_user | | wangshi | f332 | old | 2 | *** | wangshi | f332 | old_user | bronze_user | | liwei | hfd | old | 3 | *** | liwei | hfd | old_user | silver_user | | wutong | 543gdfsd | new | 6 | wutong | wutong | 543gdfsd | new_user | gold_user | | lilisi | dsfgg | new | 5 | lilisi | lilisi | dsfgg | new_user | gold_user | | qishili | fds | new | 5 | qishili | qishili | fds | new_user | gold_user | +----------+-------------+------------+--------+----------+----------+-------------+-----------+--------------+--+
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29

字符串函數(shù)

## 字符串長度:length 字符串反轉(zhuǎn):reverse 字符串連接:concat 帶分隔符字符串連接:concat_wsselect user_id,device_id,user_type,length(user_id),reverse(user_id), concat(user_id,device_id,user_type),concat_ws('_',user_id,device_id,user_type) from order_detail;+----------+-------------+------------+------+----------+-----------------------+-------------------------+--+ | user_id | device_id | user_type | _c3 | _c4 | _c5 | _c6 | +----------+-------------+------------+------+----------+-----------------------+-------------------------+--+ | zhangsa | dfsadsa323 | new | 7 | asgnahz | zhangsadfsadsa323new | zhangsa_dfsadsa323_new | | lisi | 543gfd | old | 4 | isil | lisi543gfdold | lisi_543gfd_old | | wanger | 65ghf | new | 6 | regnaw | wanger65ghfnew | wanger_65ghf_new | | liiu | fdsfagwe | new | 4 | uiil | liiufdsfagwenew | liiu_fdsfagwe_new | | qibaqiu | fds | new | 7 | uiqabiq | qibaqiufdsnew | qibaqiu_fds_new | | wangshi | f332 | old | 7 | ihsgnaw | wangshif332old | wangshi_f332_old | | liwei | hfd | old | 5 | iewil | liweihfdold | liwei_hfd_old | | wutong | 543gdfsd | new | 6 | gnotuw | wutong543gdfsdnew | wutong_543gdfsd_new | | lilisi | dsfgg | new | 6 | isilil | lilisidsfggnew | lilisi_dsfgg_new | | qishili | fds | new | 7 | ilihsiq | qishilifdsnew | qishili_fds_new |## 字符串截取函數(shù): substr,substring 語法: substr(string A, int start),substring(string A, int start) 說明:返回字符串 A 從 start 位置到結(jié)尾的字符串語法: substr(string A, int start, int len),substring(string A, int start, int len) 說明:返回字符串A從start位置開始,長度為len的字符串select user_id,substr(user_id,3),substr(user_id,-2), substring(user_id,1,2),substr(user_id,-2,2) from order_detail;+----------+--------+------+------+------+--+ | user_id | _c1 | _c2 | _c3 | _c4 | +----------+--------+------+------+------+--+ | zhangsa | angsa | sa | zh | sa | | lisi | si | si | li | si | | wanger | nger | er | wa | er | | liiu | iu | iu | li | iu | | qibaqiu | baqiu | iu | qi | iu | | wangshi | ngshi | hi | wa | hi | | liwei | wei | ei | li | ei | | wutong | tong | ng | wu | ng | | lilisi | lisi | si | li | si | | qishili | shili | li | qi | li | +----------+--------+------+------+------+--+## 字符串轉(zhuǎn)大寫:upper,ucase 字符串轉(zhuǎn)小寫:lower,lcaseselect user_id,upper(user_id),ucase(user_id), lower(upper(user_id)),lcase(ucase(user_id)),lower(ucase(user_id)) from order_detail;+----------+----------+----------+----------+----------+----------+--+ | user_id | _c1 | _c2 | _c3 | _c4 | _c5 | +----------+----------+----------+----------+----------+----------+--+ | zhangsa | ZHANGSA | ZHANGSA | zhangsa | zhangsa | zhangsa | | lisi | LISI | LISI | lisi | lisi | lisi | | wanger | WANGER | WANGER | wanger | wanger | wanger | | liiu | LIIU | LIIU | liiu | liiu | liiu | | qibaqiu | QIBAQIU | QIBAQIU | qibaqiu | qibaqiu | qibaqiu | | wangshi | WANGSHI | WANGSHI | wangshi | wangshi | wangshi | | liwei | LIWEI | LIWEI | liwei | liwei | liwei | | wutong | WUTONG | WUTONG | wutong | wutong | wutong | | lilisi | LILISI | LILISI | lilisi | lilisi | lilisi | | qishili | QISHILI | QISHILI | qishili | qishili | qishili | +----------+----------+----------+----------+----------+----------+--+## 去兩邊的空格:trim 左邊去空格:ltrim 右邊去空格:rtrimselect trim(' abc '),ltrim(' abc'),rtrim('abc ') from order_detail limit 1;+------+------+------+--+ | _c0 | _c1 | _c2 | +------+------+------+--+ | abc | abc | abc | +------+------+------+--+## 正則表達(dá)式替換: regexp_replace 說明:將字符串 A 中的符合 java 正則表達(dá)式 B 的部分替換為 C。注意,在有些情況下要使用轉(zhuǎn)義字符, 類似 oracle 中的 regexp_replace 函數(shù)。## 正則表達(dá)式解析: regexp_extract 將字符串 subject 按照 pattern 正則表達(dá)式的規(guī)則拆分,返回 index 指定的字符。 注意,在有些情況下要使用轉(zhuǎn)義字符,如等號要用雙豎線轉(zhuǎn)義,這是java正則表達(dá)式的規(guī)則。select user_id,regexp_replace(user_id, 'li|ng', '**'), regexp_extract(user_id,'li(.*?)(si)',1), regexp_extract(user_id,'li(.*?)(si)',2), regexp_extract(user_id,'li(.*?)(si)',0) from order_detail; +----------+----------+------+------+---------+--+ | user_id | _c1 | _c2 | _c3 | _c4 | +----------+----------+------+------+---------+--+ | zhangsa | zha**sa | | | | | lisi | **si | | si | lisi | | wanger | wa**er | | | | | liiu | **iu | | | | | qibaqiu | qibaqiu | | | | | wangshi | wa**shi | | | | | liwei | **wei | | | | | wutong | wuto** | | | | | lilisi | ****si | li | si | lilisi | | qishili | qishi** | | | | +----------+----------+------+------+---------+--+select regexp_extract('http://facebook.com/path1/p.php?k1=v1543643&k2=v3245#Ref1', '.*?k1\\=([^&]+)', 1), regexp_extract('http://facebook.com/path1/p.php?k1=v1543643&k2=v3245#Ref1', '.*?k2\\=([^#]+)', 1) from order_detail limit 1;+-----------+--------+--+ | _c0 | _c1 | +-----------+--------+--+ | v1543643 | v3245 | +-----------+--------+--+## URL解析:parse_url 語法: parse_url(string urlString, string partToExtract [, string keyToExtract]) 說明:返回 URL 中指定的部分。 partToExtract 的有效值為: HOST, PATH, QUERY, REF,PROTOCOL, AUTHORITY, FILE, and USERINFO. 舉例:select parse_url('http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1', 'HOST'), parse_url('http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1', 'PATH'), parse_url('http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1', 'QUERY'), parse_url('http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1', 'QUERY','k2'), parse_url('http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1', 'REF'), parse_url('http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1', 'PROTOCOL'), parse_url('http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1', 'AUTHORITY'), parse_url('http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1', 'FILE') from order_detail limit 1;+---------------+---------------+--------------+------+-------+-------+---------------+---------------------------+--+ | _c0 | _c1 | _c2 | _c3 | _c4 | _c5 | _c6 | _c7 | +---------------+---------------+--------------+------+-------+-------+---------------+---------------------------+--+ | facebook.com | /path1/p.php | k1=v1&k2=v2 | v2 | Ref1 | http | facebook.com | /path1/p.php?k1=v1&k2=v2 | +---------------+---------------+--------------+------+-------+-------+---------------+---------------------------+--+## json解析: get_json_object 語法: get_json_object(string json_string, string path) 說明:解析 json 的字符串 json_string,返回 path 指定的內(nèi)容。如果輸入的 json 字符串無效,那么返回 NULL。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'), 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" }', '$.store.fruit[0].type') from order_detail limit 1;+------+--------+--+ | _c0 | _c1 | +------+--------+--+ | amy | apple | +------+--------+--+## json_tuple 語法: json_tuple(string jsonStr,string k1,string k2, ...) 參數(shù)為一組鍵k1,k2……和JSON字符串,返回值的元組。該方法比 get_json_object 高效,因?yàn)榭梢栽谝淮握{(diào)用中輸入多個鍵.select a.user_id, b.* from order_detail a lateral view json_tuple('{"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" }', 'email', 'owner') b as email, owner limit 1;+----------+---------------------------------+--------+--+ | user_id | email | owner | +----------+---------------------------------+--------+--+ | zhangsa | amy@only_for_json_udf_test.net | amy | +----------+---------------------------------+--------+--+## parse_url_tupleSELECT b.* from ( select 'http://facebook.com/path1/p.php?k1=v1&k2=v2#Ref1' as urlstr from order_detail limit 1 )a LATERAL VIEW parse_url_tuple(a.urlstr, 'HOST', 'PATH', 'QUERY', 'QUERY:k1') b as host, path, query, query_k1 LIMIT 1;+---------------+---------------+--------------+-----------+--+ | host | path | query | query_k1 | +---------------+---------------+--------------+-----------+--+ | facebook.com | /path1/p.php | k1=v1&k2=v2 | v1 | +---------------+---------------+--------------+-----------+--+空格字符串:space 重復(fù)字符串:repeat 首字符ascii:ascii select space(10), length(space(10)), repeat('abc',5), ascii('abcde') from order_detail limit 1;+-------------+------+------------------+------+--+ | _c0 | _c1 | _c2 | _c3 | +-------------+------+------------------+------+--+ | | 10 | abcabcabcabcabc | 97 | +-------------+------+------------------+------+--+左補(bǔ)足函數(shù):lpad 右補(bǔ)足函數(shù):rpad 語法: lpad(string str, int len, string pad) 說明:lpad將 str 進(jìn)行用 pad 進(jìn)行左補(bǔ)足到 len 位, rpad將 str 進(jìn)行用 pad 進(jìn)行右補(bǔ)足到 len 位 注意:與 GP,ORACLE 不同; pad不能默認(rèn)select lpad('abc',10,'td'),rpad('abc',10,'td') from order_detail limit 1;+-------------+-------------+--+ | _c0 | _c1 | +-------------+-------------+--+ | tdtdtdtabc | abctdtdtdt | +-------------+-------------+--+分割字符串函數(shù): split集合查找函數(shù): find_in_set 語法: find_in_set(string str, string strList) 說明: 返回 str 在 strlist 第一次出現(xiàn)的位置, strlist 是用逗號分割的字符串。如果沒有找該 str 字符,則返回 0select split('abtcdtef','t'), find_in_set('ab','ef,ab,de'), find_in_set('at','ef,ab,de') from order_detail limit 1; +-------------------+------+------+--+ | _c0 | _c1 | _c2 | +-------------------+------+------+--+ | ["ab","cd","ef"] | 2 | 0 | +-------------------+------+------+--+## string轉(zhuǎn)map:str_to_map 語法:str_to_map(text[, delimiter1, delimiter2]) 說明:使用兩個分隔符將文本拆分為鍵值對。 Delimiter1將文本分成K-V對,Delimiter2分割每個K-V對。 對于delimiter1默認(rèn)分隔符是',',對于delimiter2默認(rèn)分隔符是':'。 select str_to_map('aaa:11&bbb:22', '&', ':') from order_detail limit 1; +--------------------------+--+ | _c0 | +--------------------------+--+ | {"bbb":"22","aaa":"11"} | +--------------------------+--+select str_to_map('aaa:11&bbb:22', '&', ':')['aaa'] from order_detail limit 1;+------+--+ | _c0 | +------+--+ | 11 | +------+--+select str_to_map('aaa:11,bbb:22') from person limit 1;{"bbb":"22","aaa":"11"}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195
  • 196
  • 197
  • 198
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209
  • 210
  • 211
  • 212
  • 213
  • 214
  • 215
  • 216
  • 217
  • 218
  • 219
  • 220
  • 221
  • 222
  • 223
  • 224
  • 225
  • 226
  • 227
  • 228
  • 229
  • 230
  • 231
  • 232
  • 233
  • 234
  • 235
  • 236
  • 237
  • 238
  • 239
  • 240
  • 241
  • 242
  • 243
  • 244
  • 245
  • 246
  • 247
  • 248
  • 249
  • 250
  • 251
  • 252
  • 253
  • 254
  • 255
  • 256
  • 257
  • 258
  • 259
  • 260
  • 261
  • 262
  • 263
  • 264
  • 265
  • 266
  • 267
  • 268
  • 269
  • 270
  • 271
  • 272
  • 273
  • 274
  • 275
  • 276
  • 277
  • 278
  • 279
  • 280
  • 281
  • 282
  • 283
  • 284
  • 285
  • 286
  • 287
  • 288
  • 289
  • 290
  • 291
  • 292
  • 293
  • 294
  • 295
  • 296

集合統(tǒng)計(jì)函數(shù)

## 個數(shù)統(tǒng)計(jì):count 總和統(tǒng)計(jì):sum 語法: count(*), count(expr), count(DISTINCT expr[, expr_.]) 說明: count(*)統(tǒng)計(jì)檢索出的行的個數(shù),包括 NULL 值的行; count(expr)返回指定字段的非空值的個數(shù); count(DISTINCT expr[, expr_.])返回指定字段的不同的非空值的個數(shù)語法: sum(col), sum(DISTINCT col) 說明: sum(col)統(tǒng)計(jì)結(jié)果集中 col 的相加的結(jié)果; sum(DISTINCT col)統(tǒng)計(jì)結(jié)果中 col 不同值select count(*),count(user_type),count(distinct user_type), sum(sales),sum(distinct sales) from order_detail; +------+------+------+------+------+--+ | _c0 | _c1 | _c2 | _c3 | _c4 | +------+------+------+------+------+--+ | 10 | 10 | 2 | 29 | 17 | +------+------+------+------+------+--+## 平均值統(tǒng)計(jì):avg 最小值統(tǒng)計(jì):min 最大值統(tǒng)計(jì):maxselect avg(sales),avg(distinct sales),min(sales),max(distinct sales) from order_detail;+------+------+------+------+--+ | _c0 | _c1 | _c2 | _c3 | +------+------+------+------+--+ | 2.9 | 3.4 | 1 | 6 | +------+------+------+------+--+## 標(biāo)準(zhǔn)差:stddev_samp, stddev, stddev_pop stddev_pop <==> stddev## 方差:var_samp, var_pop當(dāng)我們需要真實(shí)的標(biāo)準(zhǔn)差/方差的時候最好是使用: stddev stddev_pop var_pop 而只是需要得到少量數(shù)據(jù)的標(biāo)準(zhǔn)差/方差的近似值可以選用: stddev_samp var_sampselect var_pop(sales),var_samp(sales), stddev_pop(sales),stddev(sales),stddev_samp(sales), pow(stddev_pop(sales),2),pow(stddev_samp(sales),2) from order_detail;+-------+--------------------+---------------------+---------------------+---------------------+---------------------+---------------------+--+ | _c0 | _c1 | _c2 | _c3 | _c4 | _c5 | _c6 | +-------+--------------------+---------------------+---------------------+---------------------+---------------------+---------------------+--+ | 3.09 | 3.433333333333333 | 1.7578395831246945 | 1.7578395831246945 | 1.8529256146249728 | 3.0899999999999994 | 3.4333333333333336 | +-------+--------------------+---------------------+---------------------+---------------------+---------------------+---------------------+--+## 百分位數(shù): percentile 近似百分位數(shù): percentile_approx 直方圖: histogram_numeric語法: percentile_approx(DOUBLE col, p [, B]) 返回值: double 說明: 求近似的第 pth 個百分位數(shù), p 必須介于 0 和 1 之間,返回類型為 double,但是col 字段支持浮點(diǎn)類型。 參數(shù) B 控制內(nèi)存消耗的近似精度, B越大,結(jié)果的準(zhǔn)確度越高。默認(rèn)為 10,000。 當(dāng) col 字段中的 distinct 值的個數(shù)小于 B 時,結(jié)果為準(zhǔn)確的百分位數(shù)select percentile(sales,0.2), percentile_approx(sales,0.5,10000), histogram_numeric(sales,5) from order_detail;+------+------+----------------------------------------------------------------------------------------------+--+ | _c0 | _c1 | _c2 | +------+------+----------------------------------------------------------------------------------------------+--+ | 1.0 | 2.0 | [{"x":1.0,"y":3.0},{"x":2.0,"y":2.0},{"x":3.0,"y":2.0},{"x":5.0,"y":2.0},{"x":6.0,"y":1.0}] | +------+------+----------------------------------------------------------------------------------------------+--+select inline(histogram_numeric(sales,10)) from order_detail;+------+------+--+ | x | y | +------+------+--+ | 1.0 | 3.0 | | 2.0 | 2.0 | | 3.0 | 2.0 | | 5.0 | 2.0 | | 6.0 | 1.0 | +------+------+--+### 后面可以輸入多個百分位數(shù),返回類型也為 array<double>,其中為對應(yīng)的百分位數(shù)。 select percentile(sales,array(0.2,0.4,0.6)), percentile_approx(sales,array(0.2,0.4,0.6),10000) from order_detail;+----------------+----------------+--+ | _c0 | _c1 | +----------------+----------------+--+ | [1.0,2.0,3.0] | [1.0,1.5,2.5] | +----------------+----------------+--+
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103

復(fù)雜類型訪問操作及統(tǒng)計(jì)函數(shù)

測試數(shù)據(jù)集: tony 1338 hello,woddd 1,2 a1,a2,a3 k1:1.0,k2:2.0,k3:3.0 s1,s2,s3,4 mark 5453 kke,ladyg 2,3 a4,a5,a6 k4:4.0,k5:5.0,k2:6.0 s4,s5,s6,6 ivyfd 4323 aa,thq,dsx 3,6 a7,a8,a9 k7:7.0,k8:8.0,k2:9.0 s7,s8,s9,9 drop table employees; create external table if not exists employees( name string, salary string, happy_word string, happy_num array<int>, subordinates array<string>, deductions map<string,float>, address struct<street:string,city:string,state:string,zip:int> ) row format delimited fields terminated by '\t' collection items terminated by ',' map keys terminated by ':' lines terminated by '\n' stored as textfile;hdfs dfs -put /home/liguodong/data/muldata.txt /temp/lgdload data inpath '/temp/lgd/muldata.txt' overwrite into table employees;select * from employees;Getting log thread is interrupted, since query is done! +--------+---------+--------------+------------+-------------------+-------------------------------+---------------------------------------------------+--+ | name | salary | happy_word | happy_num | subordinates | deductions | address | +--------+---------+--------------+------------+-------------------+-------------------------------+---------------------------------------------------+--+ | tony | 1338 | hello,woddd | [1,2] | ["a1","a2","a3"] | {"k1":1.0,"k2":2.0,"k3":3.0} | {"street":"s1","city":"s2","state":"s3","zip":4} | | mark | 5453 | kke,ladyg | [2,3] | ["a4","a5","a6"] | {"k4":4.0,"k5":5.0,"k2":6.0} | {"street":"s4","city":"s5","state":"s6","zip":6} | | ivyfd | 4323 | aa,thq,dsx | [3,6] | ["a7","a8","a9"] | {"k7":7.0,"k8":8.0,"k2":9.0} | {"street":"s7","city":"s8","state":"s9","zip":9} | +--------+---------+--------------+------------+-------------------+-------------------------------+---------------------------------------------------+--+## 訪問數(shù)組 Map 結(jié)構(gòu)體select name,salary, subordinates[1],deductions['k2'],deductions['k3'],address.city from employees; +--------+---------+------+------+-------+-------+--+ | name | salary | _c2 | _c3 | _c4 | city | +--------+---------+------+------+-------+-------+--+ | tony | 1338 | a2 | 2.0 | 3.0 | s2 | | mark | 5453 | a5 | 6.0 | NULL | s5 | | ivyfd | 4323 | a8 | 9.0 | NULL | s8 | +--------+---------+------+------+-------+-------+--+## Map類型長度 Array類型長度select size(deductions),size(subordinates) from employees limit 1;+------+------+--+ | _c0 | _c1 | +------+------+--+ | 3 | 3 | +------+------+--+## 類型轉(zhuǎn)換: castselect cast(salary as int),cast(deductions['k2'] as bigint) from employees;+---------+------+--+ | salary | _c1 | +---------+------+--+ | 1338 | 2 | | 5453 | 6 | | 4323 | 9 | +---------+------+--+### LATERAL VIEW 行轉(zhuǎn)列 SELECT name, ad_subordinate FROM employees LATERAL VIEW explode(subordinates) addTable AS ad_subordinate; +--------+-----------------+--+ | name | ad_subordinate | +--------+-----------------+--+ | tony | a1 | | tony | a2 | | tony | a3 | | mark | a4 | | mark | a5 | | mark | a6 | | ivyfd | a7 | | ivyfd | a8 | | ivyfd | a9 | +--------+-----------------+--+SELECT name, count(1) FROM employees LATERAL VIEW explode(subordinates) addTable AS ad_subordinate group by name; +--------+------+--+ | name | _c1 | +--------+------+--+ | ivyfd | 3 | | mark | 3 | | tony | 3 | +--------+------+--+SELECT ad_subordinate, ad_num FROM employees LATERAL VIEW explode(subordinates) addTable AS ad_subordinate LATERAL VIEW explode(happy_num) addTable2 AS ad_num; +-----------------+---------+--+ | ad_subordinate | ad_num | +-----------------+---------+--+ | a1 | 1 | | a1 | 2 | | a2 | 1 | | a2 | 2 | | a3 | 1 | | a3 | 2 | | a4 | 2 | | a4 | 3 | | a5 | 2 | | a5 | 3 | | a6 | 2 | | a6 | 3 | | a7 | 3 | | a7 | 6 | | a8 | 3 | | a8 | 6 | | a9 | 3 | | a9 | 6 | +-----------------+---------+--+### 多個LATERAL VIEW SELECT name, count(1) FROM employees LATERAL VIEW explode(subordinates) addTable AS ad_subordinate LATERAL VIEW explode(happy_num) addTable2 AS ad_num group by name;+--------+------+--+ | name | _c1 | +--------+------+--+ | ivyfd | 6 | | mark | 6 | | tony | 6 | +--------+------+--+### 不滿足條件產(chǎn)生空行 SELECT AA.name, BB.* FROM employees AA LATERAL VIEW explode(array()) BB AS a limit 10; +-------+----+--+ | name | a | +-------+----+--+ +-------+----+--+### OUTER 避免永遠(yuǎn)不產(chǎn)生結(jié)果,無滿足條件的行,在該列會產(chǎn)生NULL值。 SELECT AA.name, BB.* FROM employees AA LATERAL VIEW OUTER explode(array()) BB AS a limit 10; +--------+-------+--+ | name | a | +--------+-------+--+ | tony | NULL | | mark | NULL | | ivyfd | NULL | +--------+-------+--+### 字符串切分成多列 SELECT name, word FROM employees LATERAL VIEW explode(split(happy_word,',')) addTable AS word;+--------+--------+--+ | name | word | +--------+--------+--+ | tony | hello | | tony | woddd | | mark | kke | | mark | ladyg | | ivyfd | aa | | ivyfd | thq | | ivyfd | dsx | +--------+--------+--+

--------------------- 本文來自 李國冬 的CSDN 博客 ,全文地址請點(diǎn)擊:https://blog.csdn.net/scgaliguodong123_/article/details/60881166?utm_source=copy?

總結(jié)

以上是生活随笔為你收集整理的Hive常用函数大全(一)(关系/数学/逻辑/数值/日期/条件/字符串/集合统计/复杂类型)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

91九色在线视频 | 最近中文字幕免费观看 | 久久伊99综合婷婷久久伊 | 天无日天天操天天干 | 最近免费观看的电影完整版 | 久精品视频免费观看2 | 国产精品9999| 激情丁香久久 | 国产精品成人自产拍在线观看 | 麻豆影音先锋 | 久草视频播放 | 亚洲精品综合欧美二区变态 | 免费看成人a | 亚洲午夜久久久久久久久 | www.com操| 国产麻豆精品在线观看 | 久要激情网 | 久久激情精品 | 一级黄色在线视频 | 久久久精品免费观看 | 日韩视频免费看 | 国产精品综合av一区二区国产馆 | 日韩欧美在线观看 | 久久9精品 | 激情一区二区三区欧美 | 日日干 天天干 | 就色干综合 | 国产精品s色 | 激情开心色 | 国产精品久久久久av福利动漫 | 免费看的黄色录像 | 久久伦理 | 亚洲男男gaygay无套 | 毛片激情永久免费 | 韩日av在线 | 欧美乱大交| 超碰97国产在线 | 国产黄色成人 | av在线一| 久久视频这里有精品 | 欧美日韩一二三四区 | 日本最新中文字幕 | 五月天色网站 | a视频免费看 | 成 人 黄 色视频免费播放 | 最近乱久中文字幕 | 国产 日韩 在线 亚洲 字幕 中文 | 麻豆影视在线观看 | 日韩色综合网 | 国产高清永久免费 | av免费看在线 | 欧美日韩一区二区在线观看 | 久久一区二区免费视频 | 久久影院午夜论 | 久久草 | 在线观看黄色 | 黄色国产区| 国产欧美精品一区二区三区四区 | 久久亚洲私人国产精品va | 超碰最新网址 | 99精品视频免费观看视频 | 久久精品99国产精品酒店日本 | 日韩在线短视频 | 十八岁以下禁止观看的1000个网站 | 91精品麻豆 | 亚洲欧美国产视频 | 制服丝袜在线91 | 美女亚洲精品 | 波多野结衣在线观看视频 | 久草在线久| 四虎在线免费观看视频 | 97久久久免费福利网址 | 欧美a视频在线观看 | 九色91av | 四月婷婷在线观看 | 麻豆国产在线视频 | 国产精品久久久区三区天天噜 | 久一在线| 亚洲精品自在在线观看 | 国产精品一级在线 | 波多野结衣在线播放一区 | 国产一区二区在线视频观看 | 国产色一区 | 国产精品一区免费在线观看 | 国色天香av | 国产高清无线码2021 | av线上看 | 国产一区免费在线 | 日本最大色倩网站www | 中文字幕日本特黄aa毛片 | 午夜精品婷婷 | 国产一级不卡毛片 | 夜夜躁日日躁 | 欧美日本啪啪无遮挡网站 | 日韩精品免费一区二区在线观看 | 午夜av剧场 | 亚洲高清91 | 在线播放 亚洲 | 国产精品视频免费在线观看 | 久久久免费看片 | 国产一级视频在线观看 | 91精品中文字幕 | 高清不卡一区二区在线 | 亚洲草视频 | 免费成人av在线看 | 国产精品久一 | 日韩亚洲国产中文字幕 | 亚洲高清免费在线 | 久久久一本精品99久久精品66 | 欧美黄污视频 | 国产日韩精品在线观看 | 99r在线 | 亚洲精品美女久久久久网站 | 国产一区在线看 | 91污在线观看 | 免费福利片2019潦草影视午夜 | 蜜臀av夜夜澡人人爽人人桃色 | 在线观看mv的中文字幕网站 | 亚洲免费av电影 | 国产成人一区二区三区电影 | 久久九九九九 | 亚洲人av免费网站 | 久久欧美在线电影 | 免费69视频 | 婷婷干五月 | 久久中文字幕视频 | 在线观看免费高清视频大全追剧 | 国产精品毛片一区二区 | 97高清免费视频 | 波多野结衣精品在线 | 亚洲夜夜网 | 久久av黄色| 午夜精品久久久久久久久久久久久久 | 欧美一级片 | 欧美一级特黄高清视频 | av不卡免费在线观看 | 久久99久久99精品免视看婷婷 | 精品国产成人av在线免 | 五月婷婷视频 | 91精品啪啪 | 国产破处在线视频 | 美女国内精品自产拍在线播放 | 欧美成人精品欧美一级乱黄 | 蜜桃麻豆www久久囤产精品 | 国产精品 日韩 欧美 | 丁香视频全集免费观看 | 91资源在线观看 | 久久99久久99 | 免费黄色特级片 | 国产精品乱码久久久久 | 丝袜美女视频网站 | 婷婷六月中文字幕 | 中文字幕丝袜制服 | 在线免费观看视频一区二区三区 | 蜜桃av人人夜夜澡人人爽 | 国产麻豆果冻传媒在线观看 | 亚洲精选视频免费看 | 欧美性超爽 | 一级黄色片毛片 | 日韩在线观看小视频 | 99中文字幕视频 | 98久9在线 | 免费 | a级国产乱理论片在线观看 特级毛片在线观看 | 色婷婷视频网 | 久久久久草 | 亚洲精品麻豆 | 91看片在线播放 | 黄色在线免费观看网址 | 久色 网 | 久久人人做 | 久久av高清 | 在线影院 国内精品 | 91成人精品一区在线播放69 | 在线观看亚洲a | 黄色一级在线观看 | 玖玖爱在线观看 | 久久久久国产一区二区三区四区 | 亚洲国产免费看 | 99久久精品国产一区二区成人 | 天天插天天色 | 97香蕉久久国产在线观看 | 午夜影院日本 | 色婷婷97 | 干狠狠 | 日本aaaa级毛片在线看 | 成人久久久精品国产乱码一区二区 | 黄色免费在线看 | 一区免费视频 | 国产麻豆精品久久一二三 | 中文字幕在线观看三区 | 国际精品久久久久 | 狠狠干夜夜 | 国产三级午夜理伦三级 | 日韩电影在线视频 | 夜夜操夜夜干 | 在线中文字幕观看 | 国产精品不卡av | 国产系列 在线观看 | 久久综合九色综合欧美就去吻 | 天海冀一区二区三区 | 国产v亚洲v | 欧美二区三区91 | 国产一级二级在线播放 | 亚洲一片黄 | 日韩精品欧美视频 | 中文字幕在线资源 | 天天操天天干天天插 | 久久免费视频2 | 久久久国产在线视频 | 久久精品国产99 | 四虎国产精品成人免费4hu | 日韩免费在线视频 | 亚洲成人精品在线观看 | 中文字幕在线观看免费观看 | 在线国产中文字幕 | 99在线观看视频网站 | 亚洲激情影院 | 欧美地下肉体性派对 | 亚洲禁18久人片 | 久久免费看av | 天天摸天天弄 | 久久久久久久久久久综合 | 在线观看av不卡 | 麻豆精品视频 | 精品一区二区三区久久久 | 午夜一级免费电影 | 美女黄色网在线播放 | 亚洲精品美女在线观看播放 | 国产一区精品在线观看 | 日日日干 | 久草电影免费在线观看 | 激情综合婷婷 | 91精品电影 | 色小说在线 | 日韩在线观看三区 | 夜夜躁日日躁狠狠久久av | 激情网站免费观看 | 精品久久电影 | 国产综合精品久久 | 精品96久久久久久中文字幕无 | 麻豆91精品91久久久 | 久久久国产99久久国产一 | 国产精品手机看片 | 久久精品高清视频 | 久久污视频 | 免费看一级 | 中文字幕亚洲字幕 | 久久精品这里热有精品 | 久草在线综合 | 国产精品专区h在线观看 | 麻豆影视在线观看 | 欧洲精品码一区二区三区免费看 | 天天干天天干天天干天天干天天干天天干 | 99精品小视频 | 中文电影网 | 免费日韩一级片 | 久久午夜网| 久草在线一免费新视频 | 精品久久久久国产免费第一页 | 少妇高潮冒白浆 | 日韩视频在线观看视频 | 日韩精品一区二区三区视频播放 | 99r在线精品 | 久久久久免费精品视频 | 中文在线a√在线 | 九九免费精品 | 日韩av一区二区三区在线观看 | 国产尤物在线视频 | 91av亚洲 | www.综合网.com | www.五月激情.com| 九九视频在线播放 | 色爱成人网 | 亚洲在线成人精品 | 亚洲 欧洲av | 91精品视频在线看 | 久久官网 | 国内精品视频一区二区三区八戒 | 91精品网站在线观看 | 五月综合色婷婷 | 久久国产精品免费看 | 免费日韩一区二区三区 | 色偷偷网站视频 | 国产专区精品 | 色资源网免费观看视频 | 2022国产精品视频 | 天天干天天草天天爽 | 播五月婷婷 | av综合站 | 91精品国自产在线观看 | 蜜臀av性久久久久av蜜臀妖精 | 天天综合视频在线观看 | 久久成熟| 国产精品视频app | 亚洲国产最新 | 日日爽日日操 | 婷婷成人在线 | 久久好看免费视频 | 日韩欧美电影在线 | 午夜 免费| 欧美精品二区 | 日本在线中文在线 | 日韩在线播放欧美字幕 | 97超级碰碰 | 天天操天天干天天爱 | 中文一区在线观看 | 日韩av视屏 | 区一区二在线 | 日韩动态视频 | 久久免费视屏 | 日本精品视频在线观看 | 日韩欧美一区二区三区免费观看 | 日本一区二区三区视频在线播放 | 69国产成人综合久久精品欧美 | 亚洲视频久久久久 | av高清网站在线观看 | 成人在线电影观看 | 一级黄色a视频 | 成人免费 在线播放 | 亚洲区另类春色综合小说校园片 | 激情视频一区二区三区 | 成全免费观看视频 | 亚洲精品美女久久 | 国产91精品一区二区绿帽 | 国产精品久久久久久久午夜 | 国产精品久久久久久a | 久久精品视频在线播放 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 天天射网站 | 久久视频这里只有精品 | 久久久国产一区二区三区四区小说 | 五月婷婷av | 成人黄色在线观看视频 | 成人精品视频久久久久 | 高清av免费观看 | 色多多视频在线 | 97国产| 黄色成人在线 | 91精品第一页 | 久久久久国产一区二区三区 | 久久爱资源网 | 97碰在线视频 | 韩国av电影在线观看 | 成年人在线观看 | 亚洲精品视 | 特级毛片网 | 黄色99视频 | 99国产高清 | 波多野结衣网址 | 99免费看片| 天天干天天草天天爽 | 亚洲女人天堂成人av在线 | 成年人在线视频观看 | 精品a视频 | 丁香激情综合 | 日本黄色片一区二区 | 在线观看免费av片 | 久久视频一区 | 日韩av资源站 | 三级大片网站 | 亚洲 中文 在线 精品 | 99国产视频| 日韩 精品 一区 国产 麻豆 | 免费a网址| 天天舔夜夜操 | 精品一区 精品二区 | 中文字幕日韩av | 97在线观看免费观看高清 | 五月天六月丁香 | 天天干夜夜 | 日本精品久久久久中文字幕 | 亚洲深夜影院 | 国产99re| 超薄丝袜一二三区 | 国产精品一区二区久久久 | 91成人免费 | 午夜av一区 | 久久综合九色综合欧美狠狠 | 99在线看| 97超碰国产精品女人人人爽 | 777奇米四色 | 久久av在线 | 久久久香蕉视频 | 在线观看视频你懂的 | 九九热免费观看 | 国产免费视频在线 | 九九视频在线观看视频6 | 在线观看国产91 | 日韩欧美在线视频一区二区三区 | 日韩av电影国产 | 日本黄色大片免费看 | 手机av观看 | 国内精品毛片 | 黄色网在线免费观看 | 丁香婷婷激情网 | 国产一级免费片 | 国产色婷婷精品综合在线手机播放 | 91麻豆精品国产午夜天堂 | 一区二区三区在线播放 | 91精品国自产在线观看 | 国产无吗一区二区三区在线欢 | 亚洲精品乱码久久久久久蜜桃不爽 | 日韩免费三级 | 欧美日韩二区在线 | www五月天com| 亚洲最新av在线网址 | 色综合久久久 | 天天天天爱天天躁 | 国产精品自产拍在线观看中文 | 久久九九视频 | 国产精品99久久久久久有的能看 | 美女网站在线看 | 另类老妇性bbwbbw高清 | 最新不卡av | 99久久国产免费看 | 草免费视频 | 久久成人麻豆午夜电影 | 久久av观看 | 中文字幕影视 | 国产码电影 | 亚洲精品网址在线观看 | 天天干天天天天 | 婷婷在线视频 | 亚洲欧美日韩不卡 | 欧美日韩亚洲在线 | 国产精品一区一区三区 | 九九热免费观看 | 精品国产一区二 | 亚洲久草在线视频 | 日韩精品专区在线影院重磅 | 日韩精品一区二区在线 | 97免费在线观看视频 | 日韩免费一区二区三区 | 天天综合精品 | 97精品一区二区三区 | 国产一级免费视频 | 国产一区二区久久精品 | 免费观看国产精品视频 | 亚洲高清精品在线 | 九九影视理伦片 | 国产精品丝袜久久久久久久不卡 | 久久桃花网 | 97精品国产| 日本精品视频在线观看 | 国产美女精品 | 很黄很污的视频网站 | 日韩性xxxx| 国产精品久久99精品毛片三a | 日批网站免费观看 | 日韩精品偷拍 | 91亚色免费视频 | 日本久草电影 | 久久久久国产精品免费 | 色婷婷av国产精品 | 爱情影院aqdy鲁丝片二区 | 亚洲精品在线免费播放 | www.久久视频 | 精品女同一区二区三区在线观看 | 国产成人久久精品77777综合 | 亚洲伦理一区二区 | 精品国产伦一区二区三区免费 | 日韩在线视频免费播放 | 中文字幕精品一区二区精品 | 中文字幕在线久一本久 | 色婷婷综合久久久 | 一级成人网 | 一 级 黄 色 片免费看的 | 日韩系列在线观看 | 成人毛片100免费观看 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 国产精品免费看久久久8精臀av | 黄色免费视频在线观看 | 亚洲成人黄色在线观看 | 日韩精品首页 | 国产成人久久精品亚洲 | 欧美一区日韩一区 | 日日夜夜免费精品 | 91热在线 | 99久久99久久免费精品蜜臀 | 中国一 片免费观看 | 麻豆综合网| 久久久国产精品一区二区中文 | 五月av在线| 欧美激情综合五月色丁香 | 久久国产精品免费 | 日本高清中文字幕有码在线 | 免费网站黄| 亚洲电影院| 国产精品剧情在线亚洲 | 99视频偷窥在线精品国自产拍 | 欧美日韩中文另类 | 黄色三级免费 | 国产免码va在线观看免费 | 99久久精品久久久久久清纯 | 欧美精品免费在线观看 | 国产日韩欧美视频在线观看 | 成人午夜剧场在线观看 | 久久a v视频 | 日韩精品久久久久久久电影99爱 | 国产999精品久久久 免费a网站 | 午夜精品久久久久久中宇69 | 操操操人人 | 日韩欧美在线综合网 | 日韩一区二区三区高清免费看看 | 国产精品色视频 | 开心色婷婷 | 九九免费观看全部免费视频 | 欧美黄在线| av电影在线观看 | 国产精品一区二区在线免费观看 | 超碰日韩 | 日韩色综合| 精品久久久久久久久久久久 | 精品91久久久久 | 国产丝袜美腿在线 | 欧美精品九九99久久 | 亚在线播放中文视频 | 欧美一级专区免费大片 | 久久久91精品国产一区二区三区 | 九九99| 亚洲国产精品电影 | 超碰97中文 | 在线视频app| 极品美女被弄高潮视频网站 | 日韩手机在线 | 亚洲电影在线看 | 国产拍在线 | 人人爱爱人人 | 久久久久久久99 | 9999国产精品| 91高清视频 | 九色福利视频 | 特级黄色视频毛片 | 国内精品久久久久久久久久久 | 国产精品日韩精品 | 久久999精品| 天堂av高清 | 天天艹天天干天天 | 成人黄色中文字幕 | 欧美日韩免费一区二区三区 | 国产精品情侣视频 | 亚洲黄色片 | 一区二区三区日韩在线观看 | 久久久亚洲影院 | 91视频88av | 日韩一区二区免费在线观看 | 婷婷成人综合 | 在线观看免费国产小视频 | 国产一区二区在线免费播放 | 狠狠狠狠狠干 | 激情深爱.com | 久久久久久久久久免费视频 | 成年人黄色av| 在线免费看黄色 | 亚洲视频在线观看 | 午夜在线观看影院 | 在线观看免费视频 | 欧美日韩精品在线一区二区 | 国产一区二区不卡在线 | 精品一区二区三区久久久 | 久久久色 | 亚洲成人中文在线 | 91精品国自产在线偷拍蜜桃 | 国产精品av在线免费观看 | 亚洲成人国产精品 | 日韩精品一区二区三区免费观看 | 国产h片在线观看 | 狠狠色丁香婷综合久久 | 欧美巨大荫蒂茸毛毛人妖 | 91刺激视频 | 波多野结衣在线中文字幕 | 国产成人在线观看免费 | 四虎影视成人精品国库在线观看 | 亚洲一区二区三区毛片 | 99精品国产一区二区三区麻豆 | 成人av影院在线观看 | 日本精品在线 | 伊人中文字幕在线 | 一级黄色视屏 | 色偷偷人人澡久久超碰69 | 亚洲理论片在线观看 | 日本一区二区三区视频在线播放 | 在线国产日本 | 成人国产精品电影 | 国产一区在线视频播放 | 欧美日韩性| 欧美 日韩 成人 | 天堂久久电影网 | 9色在线视频 | 丁香影院在线 | 91成人免费视频 | 亚洲国产日韩av | www日韩在线观看 | 欧美在一区 | 亚洲欧美乱综合图片区小说区 | 国产精品6 | 中文字幕人成一区 | 欧美精品在线免费 | 福利片免费看 | 亚洲天天在线 | 欧美在线视频一区二区 | 成年人免费看片 | 狠狠色狠狠色 | 91成人网在线播放 | 日本xxxxav | www.夜夜爽 | 玖草在线观看 | 国产日产精品一区二区三区四区的观看方式 | 午夜精品久久久久久久久久久 | 丁香花在线观看免费完整版视频 | 91视频传媒 | av资源中文字幕 | 天天摸日日摸人人看 | 精品久久久久一区二区国产 | 中文字幕日本在线 | 91精品啪在线观看国产81旧版 | 国产成人一区二区三区免费看 | jizz999| 国产中文字幕一区二区 | 免费一区在线 | 国产精品免费观看国产网曝瓜 | 色婷婷狠狠 | 久久久久久久99精品免费观看 | 国产小视频在线观看免费 | 亚洲成人网在线 | 国产最新视频在线 | 激情丁香在线 | 亚洲成av人片在线观看www | 91在线一区二区 | 射射色| 日韩天天综合 | 亚洲精品三级 | 四虎在线观看网址 | 欧美日韩三级在线观看 | 99久久电影| 日本三级久久久 | 五月在线视频 | 最近更新好看的中文字幕 | 色婷五月天| 日韩免费中文字幕 | 中文字幕在线观看第三页 | 国产理论影院 | 黄色一级在线免费观看 | 国产美女主播精品一区二区三区 | 日韩最新在线视频 | 热re99久久精品国产66热 | 天天操天天操天天操天天操 | 中文字幕人成一区 | 国产在线a免费观看 | 日韩高清二区 | 日韩欧美电影在线 | 草久在线 | 日日夜夜亚洲 | 色就干| 中文伊人 | 精品久久久国产 | 夜色资源网 | 狂野欧美激情性xxxx欧美 | 天天天操操操 | 在线观看成人毛片 | 国产精品久久久久久影院 | 国产精品欧美久久久久天天影视 | 国产精品久久久久久久久久免费看 | 欧美大香线蕉线伊人久久 | 伊人丁香 | 久久久久亚洲国产 | 午夜精品区 | 国产欧美日韩一区 | 最近中文字幕 | 亚洲国产日韩一区 | 国产精品1区2区 | 91色综合 | 亚洲精品在线观 | 美女一级毛片视频 | 天天干天天操天天拍 | 欧美-第1页-屁屁影院 | 国产精品一区二区中文字幕 | 日韩精品aaa| 久艹在线播放 | 日韩中文在线视频 | 97色综合| 日韩三级视频 | 精品亚洲成人 | 久久免费国产精品 | 国产一性一爱一乱一交 | 国产高清视频在线播放一区 | 99久久婷婷国产一区二区三区 | 视频在线91| 日韩精品一区在线观看 | 麻豆视频在线 | 午夜精品视频一区 | 精品在线免费视频 | 三级黄在线 | 国内毛片毛片 | 国产午夜免费视频 | 亚洲精品一区二区三区新线路 | 69av免费视频| 日韩成人黄色 | 日韩视频免费 | 国产日韩欧美自拍 | 国产美腿白丝袜足在线av | 中文字幕一区二区三区在线视频 | 国产精品粉嫩 | 狠狠干五月天 | 97成人精品视频在线播放 | 欧美一级免费片 | 欧美aaaxxxx做受视频 | 久久黄色免费视频 | 亚洲国内精品在线 | 欧美 日韩精品 | 日韩av片免费在线观看 | 欧美一区二区三区四区夜夜大片 | 午夜体验区 | 国产亚洲久一区二区 | 黄色录像av | 不卡av在线| 插久久 | 欧美日韩中文字幕在线视频 | 久久精品国亚洲 | 91在线视频导航 | 日韩网站在线看片你懂的 | 国产精品成人一区二区三区吃奶 | 蜜桃视频在线视频 | 欧美一级专区免费大片 | 国产欧美综合视频 | 最近中文字幕视频完整版 | 亚洲综合色婷婷 | 人人超碰97 | 日本中文在线 | 日韩黄色av网站 | 久久情侣偷拍 | avwww在线 | 人人看人人爱 | 伊人久久国产精品 | 五月开心激情网 | 国产精品久99 | 九九热.com| 亚洲精品综合在线 | 中文在线免费一区三区 | 一区中文字幕 | 国产vs久久| 久久久色| 国产免费三级在线观看 | 国语久久 | 亚洲精品国产麻豆 | 天天干天天操天天搞 | 一区二区三区四区在线 | 久久一区国产 | 国产精品婷婷午夜在线观看 | 四虎影视久久久 | 91av中文字幕 | 久草免费新视频 | 又黄又爽又无遮挡的视频 | 国产亚洲片 | 手机av在线免费观看 | 免费黄色激情视频 | 黄色毛片大全 | 欧美日韩精品免费观看 | 亚洲一区二区三区精品在线观看 | 在线播放亚洲 | 亚洲成a人片在线观看网站口工 | 日韩久久视频 | 成人9ⅰ免费影视网站 | 国产高清视频 | 免费色视频| 69国产盗摄一区二区三区五区 | 亚洲va韩国va欧美va精四季 | 亚洲第一成网站 | 黄色h在线观看 | 91插插插免费视频 | 国产成人一区二区啪在线观看 | 免费黄a | 亚洲欧美乱综合图片区小说区 | 91久久影院| 久久综合久久伊人 | 国产亚洲精品成人av久久影院 | 色综合久久网 | 国产中文字幕91 | 美女视频黄频 | 色成人亚洲 | 免费十分钟 | 高潮久久久久久 | 免费看片成年人 | 韩国一区二区三区视频 | 三级a视频 | 久久免费在线观看 | 日韩精品首页 | 中文字幕在线影视资源 | 久草精品在线观看 | 伊人中文网 | 精品国产综合区久久久久久 | 又色又爽又激情的59视频 | 九九影视理伦片 | 激情视频一区二区 | 日韩一区二区三区免费视频 | 狠狠色噜噜狠狠狠狠 | 香蕉精品视频在线观看 | 波多野结衣最新 | 精品一二三区 | 最近中文字幕 | 午夜久久美女 | 日韩中文字幕在线不卡 | 欧洲一区精品 | 色综合在 | 欧美日韩18 | 婷婷精品国产一区二区三区日韩 | 亚洲专区一二三 | 在线观看中文字幕视频 | 中文字幕色在线视频 | 成人欧美在线 | 国产成人香蕉 | 激情综合网五月 | 日韩激情小视频 | www.av在线.com | 国产精品18p | 日日夜夜人人精品 | 日韩资源在线观看 | 99视频+国产日韩欧美 | 91尤物在线播放 | 日韩不卡高清 | 国产精品一区二区三区观看 | 欧美日韩综合在线观看 | 人人澡人人添人人爽一区二区 | 又黄又爽又刺激视频 | 国产99在线播放 | 激情视频网页 | 69国产盗摄一区二区三区五区 | 中文国产字幕 | 97国产超碰| 丁香久久久 | 五月婷社区 | 久久久国产毛片 | 在线视频一区二区 | 国产视频一级 | 超碰97免费观看 | av黄色在线观看 | 一区二区视 | 亚洲精品乱码久久久久v最新版 | 国产欧美在线一区二区三区 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 手机av永久免费 | 深夜国产在线 | 91麻豆精品国产91久久久久久久久 | 91在线视频免费 | 国产一区二区三区久久久 | 亚洲在线精品视频 | 一区免费视频 | 四虎天堂| 天天色综合天天 | 国产麻豆精品传媒av国产下载 | 国产精品嫩草影视久久久 | 伊人久久婷婷 | 在线一二三区 | 麻豆免费精品视频 | 性色av免费在线观看 | 欧美国产一区二区 | 亚洲精品视频在线播放 | 中文av在线天堂 | 五月激情久久久 | 欧美精品久久久久久久久免 | 免费中文字幕在线观看 | 三级av在线 | 国产精品一区二区免费 | 99视频在线看| 在线观看视频在线观看 | 91精品久久久久久综合乱菊 | 日韩欧在线 | 69av在线播放 | 欧美一区二区在线免费看 | 日本午夜在线亚洲.国产 | 丝袜足交在线 | 正在播放 久久 | 天天操天天射天天爱 | 亚洲精品电影在线 | 成年免费在线视频 | 欧美视屏一区二区 | 久久精品第一页 | 日韩视频一区二区 | 久久国产精品一区二区三区四区 | 成人午夜影视 | 国产亚洲日本 | 免费看黄电影 | 久久这里只精品 | 久久日韩精品 | 日韩精品一区在线播放 | 天天干视频在线 | 日韩在线观看视频网站 | 深夜国产福利 | 成人久久18免费网站 | 色就是色综合 | 精品视频在线免费 | 中文亚洲欧美日韩 | 久久九精品 | 亚洲狠狠丁香婷婷综合久久久 | 在线观看免费黄视频 | 热久久99这里有精品 | 久久国产精品一区二区三区四区 | 色永久免费视频 | 久久精品国产一区二区三 | av电影 一区二区 | 欧美色婷| 天天插天天操天天干 | 免费a网址 | 成人在线小视频 | 午夜精品视频一区 | 久久免费观看少妇a级毛片 久久久久成人免费 | 国产精品久久99综合免费观看尤物 | 日韩免费不卡av | 国产字幕在线看 | 久草在线国产 | 国产精品视频内 | 国产福利中文字幕 | 日本爱爱免费视频 | 成人h视频| 日本狠狠干| 国产在线播放不卡 | 国产精品欧美精品 | 黄色的视频网站 | 国产精品免费看久久久8精臀av | 人人澡超碰碰97碰碰碰软件 | 久久久免费电影 | 99这里精品 | 国产日产欧美在线观看 | 69久久夜色精品国产69 | 欧美日韩国产xxx | 久久综合中文字幕 | 亚洲天堂毛片 | 日韩在线观看视频免费 | 97精品国产97久久久久久春色 | 免费午夜网站 | 91cn国产在线 | 久久99最新地址 | 色噜噜噜噜 | 91精品欧美一区二区三区 | 亚洲精品综合一区二区 | 欧美一级在线看 | 国产精品av电影 | 国产精品18videosex性欧美 | 超碰电影在线观看 | 五月婷婷中文网 | 亚洲国内精品 | 亚洲乱码精品久久久久 | 在线观看免费国产小视频 | 精品黄色在线 | 日韩av一区二区在线影视 | 在线a人片免费观看视频 | 国产精品久久久久免费 | 精品三级av | 久久久久国产精品一区 | 久草视频中文在线 | 国产精品99久久久久久久久 | 超碰在线观看97 | 成人国产一区二区 | 狠狠色噜噜狠狠狠狠2022 | 日韩有码在线观看视频 | 色天天综合久久久久综合片 | 在线电影 一区 | 国产高清视频在线观看 | 久久精品波多野结衣 | 亚洲人成在线电影 | av资源免费看 | 三级动图 | 一级免费黄视频 | 亚洲视频在线播放 | 国产黄色大片免费看 | 国产麻豆精品一区 | 国产精品中文字幕av | 久久色中文字幕 | 日本久久久亚洲精品 | 欧美美女视频在线观看 | 国产亚洲一区二区在线观看 | 亚洲三级黄色 | 手机av电影在线观看 | 一区二区精品在线观看 | 亚洲成人软件 | 一个色综合网站 | 日韩网站在线播放 | 国产青青青 | 久久福利电影 | 色综合久久综合网 | 久久国产精品小视频 | 免费色视频网址 | 亚洲精品国偷拍自产在线观看蜜桃 | japanesexxx乱女另类 | 日日躁夜夜躁aaaaxxxx | 国产视频 久久久 | 欧美专区亚洲专区 | 国产探花 | 91亚洲精品久久久蜜桃 | 中文区中文字幕免费看 | 日韩久久久久久久久久久久 | 欧美精品被 | 91视频传媒 | 国产人成看黄久久久久久久久 | 欧美va电影| 久久久香蕉视频 | 日韩激情第一页 | 精品视频中文字幕 |