很可惜 T 。T 您現(xiàn)在還不是作者身份,不能自主發(fā)稿哦~
如有投稿需求,請把文章發(fā)送到郵箱tougao@appcpx.com,一經(jīng)錄用會有專人和您聯(lián)系
咨詢?nèi)绾纬蔀榇河鹱髡哒埪?lián)系:鳥哥筆記小羽毛(ngbjxym)
公司新入職了的產(chǎn)品經(jīng)理小美因為業(yè)務(wù)需要,想搭一個數(shù)據(jù)大屏方便自己查看數(shù)據(jù)。她找開發(fā)小王申請了數(shù)倉權(quán)限,然后從技術(shù)中臺里找到了數(shù)據(jù)大屏的工具,把自己平時查數(shù)據(jù)用的sql搬上去跑,結(jié)果總是報錯。
小美找到了做數(shù)據(jù)產(chǎn)品經(jīng)理的師兄小帥看了看。
小帥:你這個查詢有問題,業(yè)務(wù)系統(tǒng)的sql不能直接搬來用。
小美:我看長得差不多啊,除了多了個分區(qū)外,不都是sql嗎?
小帥:你現(xiàn)在建的是Hive查詢,Hive SQL雖說和SQL非常相似,但是一些細節(jié)上還是有區(qū)別的。
Hive是大數(shù)據(jù)領(lǐng)域常用的數(shù)據(jù)倉庫組件,可以借助查詢語言SQl將HDFS上存儲的結(jié)構(gòu)化文件映射成一張數(shù)據(jù)庫表,并提供類SQL查詢功能。Hive-SQL就是這個”類SQL查詢功能”。Hive-SQL與SQL基本上一樣,因為當(dāng)初的設(shè)計目的,就是讓會SQL不會編程MapReduce的也能完成處理數(shù)據(jù)工作。
【拓展】Hive-SQL是如何轉(zhuǎn)化為MapReduce任務(wù)的呢?整個編譯過程分為六個階段:
1) Antlr定義SQL的語法規(guī)則,完成SQL詞法,語法解析,將SQL轉(zhuǎn)化為抽象語法樹AST Tree
2) 遍歷AST Tree,抽象出查詢的基本組成單元QueryBlock
3) 遍歷QueryBlock,翻譯為執(zhí)行操作樹OperatorTree
4) 邏輯層優(yōu)化器進行OperatorTree變換,合并不必要的ReduceSinkOperator,減少shuffle數(shù)據(jù)量
5) 遍歷OperatorTree,翻譯為MapReduce任務(wù)
6)物理層優(yōu)化器進行MapReduce任務(wù)的變換,生成最終的執(zhí)行計劃
這里簡單介紹一下其中的幾個關(guān)鍵部分:
Antlr:Antlr是一種語言識別的工具,用來實現(xiàn)SQL的詞法和語法解析,完成包括詞法分析、語法分析、語義分析、中間代碼生成等過程。使用時只需要編寫對應(yīng)的語法文件,定義詞法和語法替換規(guī)則即可。
抽象語法樹AST Tree:經(jīng)過詞法和語法解析后,使用 Antlr 的抽象語法樹語法Abstract Syntax Tree,將輸入語句轉(zhuǎn)換成抽象語法樹,方便后續(xù)進一步的處理。
QueryBlock:AST Tree仍然非常復(fù)雜,不夠結(jié)構(gòu)化,不方便直接翻譯為MapReduce程序,AST Tree轉(zhuǎn)化為QueryBlock就是將SQL進一步抽象和結(jié)構(gòu)化。QueryBlock是一條SQL最基本的組成單元,包括三個部分:輸入源,計算過程,輸出。簡單來講一個QueryBlock就是一個子查詢。我們在查看HiveSQL查詢?nèi)罩緯r會看到一個個流程塊,這就是分拆出來的QueryBlock。
小美的查詢語句中用了HAVING子句,這個是Hive不支持的,可以用子查詢來代替。然后小帥為小美講了講HiveSQL的基本語法。
常用的顯示命令
show databases; -- 查看有哪些庫
show tables; -- 查看當(dāng)前庫下有哪些表
show partitions; -- 查看分區(qū)
show functions; -- 羅列所有的函數(shù)
describe extended table_name; -- 查看表的結(jié)構(gòu),字段,分區(qū)等情況
常用庫、表操作
create database name; -- 創(chuàng)建數(shù)據(jù)庫
create [external]table [if not exists] table_name --創(chuàng)建表,指定表名。external 表示創(chuàng)建的表是否為外部表,不加此項則為內(nèi)部表。if not exists 表示該表不存在時創(chuàng)建該表,否則忽略異常。
[(col_name data_type [comment col_comment], ...)] -- 創(chuàng)建字段,指定字段類型、注釋
[comment table_comment] -- 表的注釋
[partitioned by(col_name data_type [comment col_comment], col_name_2 data_type_2, ...)] -- 指定分區(qū),要注意分區(qū)字段不能出現(xiàn)的建表的字段中
[clustered by(col_name, col_name_2, ...)] [sorted by (col_name [ASC|DESC], ...)] into num_buckets buckets] -- 分桶
[row format row_format]
[stored as file_format] -- 指定存儲文件類型。textfile純文本數(shù)據(jù),sequencefil壓縮數(shù)據(jù)(可節(jié)省存儲空間)。
[location hdfs_path] -- 存儲路徑
create table table_name like old_table_name; -- 使用like關(guān)鍵字復(fù)制表結(jié)構(gòu)
alter table table_name rename to new_table_name; -- 更改表名
alter table table_name add columns (col_name data_type comment 'col_comment'); -- 增加一個字段并添加注釋
alter table table_name replace columns (col_name data_type, col_name_2 data_type_2); -- 刪除列
alter table table_name add [if not exists] partition_name; -- 增加分區(qū)
alter table table_name drop partition_name, partition_name_2; -- 刪除分區(qū)
常用數(shù)據(jù)操作
insert into table_1 select * from table_2; -- 在table_1后追加數(shù)據(jù)
insert overwrite table_1 select * from table_2; -- 先將table_1中數(shù)據(jù)清空,然后添加數(shù)據(jù)
常用查詢操作
HiveSQL的查詢語句結(jié)構(gòu)和SQL一致,除了前面提到的HAVING子句問題外,還需要注意的是HiveSQL中沒有not null,當(dāng)字段為null時,使用\n代替。
小美的查詢中有兩處函數(shù)調(diào)用錯誤:
1) 用了GROUP_CONCAT()函數(shù),這個在HiveSQL中沒有,但是可以用CONCAT_WS()函數(shù)代替;
2) 是substring_index()函數(shù),這個應(yīng)該替換成split()函數(shù)。
然后小帥為小美講了講Hive中的常用函數(shù)。
數(shù)學(xué)函數(shù)
bin(int d) -- 計算二進制值d的string值
rand(int seed) -- 返回隨機數(shù),seed是隨機因子
round(double d,int n) -- 返回保留n位小數(shù)的近似d值
floor(double d) -- 返回小于d的最大整值
ceil(double d) -- 返回大于d的最小整值
日期函數(shù)
current_date() -- 返回當(dāng)前日期
unix_timestamp() -- 返回當(dāng)前時間的unix時間戳,也可指定某一特定日期。如unix_timestamp('2021-01-13','yyyy-mm-dd')=1610513364
from_unixtime() -- 返回unix時間戳的日期。如selectfrom_unixtime(unix_timestamp('2021-01-13','yyyy-mm-dd'),'yyyymmdd')='20210113'
to_date(string timestamp) -- 返回時間字符串中的日期部分,如to_date('2021-01-0100:00:00')='2021-01-01'
year(date) -- 返回日期date的年,如year('2021-01-01')=2021
month(date) -- 返回日期date的月,如month('2021-01-01')=1
day(date) -- 返回日期date的天,如day('2021-01-01')=1
weekofyear(date) -- 返回日期date位于該年第幾周,如weekofyear('2021-01-01')=1
datediff(date1, date2) -- 返回日期date1與date2相差的天數(shù),如datediff('2021-01-01','2021-01-02')=1
date_add(date,int1) -- 返回日期date加上int1的日期,如date_add('2021-01-01',2)='2021-01-03'
date_sub(date,int1) -- 返回日期date減去int1的日期,如date_sub('2021-01-03',2)='2021-01-01'
months_between(date1,date2) -- 返回date1與date2相差月份,如months_between('2021-03-01','2021-01-01')=2
add_months(date,int1) -- 返回date加上int1個月的日期,int1可為負數(shù)。如add_months('2021-02-01',-1)='2021-01-01'
last_day(date) -- 返回date所在月份最后一天。如last_day('2021-01-01')='2021-01-31'
next_day(date,day1) -- 返回日期date后下個星期day1的日期。day1為星期X的英文前兩字母如next_day('2021-01-013','MO') 返回'2021-01-18'
trunc(date,string1) -- 返回日期所在月的第一天或所在年的第一天。String1可為年(YYYY/YY/YEAR)或月(MONTH/MON/MM)。如trunc('2021-01-13','MM')='2021-01-01',trunc('2021-02-01','YYYY')='2021-01-01'
字符串函數(shù)
length(string) -- 返回字符串長度
concat(string1,string2) -- 返回拼接string1及string2后的字符串
concat_ws(sep, string1,string2) -- 返回按指定分隔符sep拼接后的字符串
lower(string) -- 返回小寫字符串,同lcase(string)。
upper(string) -- 返回大寫字符串,同ucase(string)。
ascii(string) -- 返回字符串第一個字符的ascii值。
space(int1) -- 返回int1長度的空格字符串。
trim(string) -- 去掉字符串左右空格。
ltrim(string) -- 去掉字符串左空格。
rtrim(string) -- 去掉字符串右空格。
repeat(string,int1) -- 返回重復(fù)string字符串int1次后的字符串。
reverse(string) -- 返回string反轉(zhuǎn)后的字符串。如reverse('abc')='cba'
lpad(string,len1,pad1) -- 以pad1字符左填充string字符串,至len1長度。如rpad('abc',5,'1')='11abc'。
rpad(string,len1,pad1) -- 以pad1字符右填充string字符串,至len1長度。如rpad('abc',5,'1')='abc11'。
split(string,pat1) -- 以pat1正則分隔字符串string,返回數(shù)組。如split('a,b,c',',') = ["a","b","c"]
substr(string,index1,int1) -- 從index位置起截取int1個字符。如substr('abcde',1,2)='ab'
regexp_replace(string1,string2, string4) --正則表達式替換函數(shù)。將字符串1中的符合正則表達式string2的部分替換為string3。如regexp_replace(‘a(chǎn)bcde, ‘b|c|d’, ”)=’ae’
聚合函數(shù)
count(col) -- 統(tǒng)計行數(shù)
sum(col) -- 統(tǒng)計指定列和
avg(col) -- 統(tǒng)計指定列平均值
min(col) -- 返回指定列最小值
max(col) -- 返回指定列最大值
窗口函數(shù)
row_number() over(partitiion by .. order by .. ) -- 根據(jù)partition排序,相同值取不同序號,不存在序號跳躍
rank() over(partition by .. order by ..) -- 根據(jù)partition排序,相同值取相同序號,存在序號跳躍
dense_rank() over(partition by .. order by ..) -- 根據(jù)partition排序,相同值取相同序號,不存在序號跳躍
lag(col,n) over(partition by .. order by ..) --查看當(dāng)前行的上第n行
lead(col,n) over(partition by .. order by ..) -- 查看當(dāng)前行的下第n行
轉(zhuǎn)換函數(shù)
cast(col as dtype) --將指定值轉(zhuǎn)換為指定數(shù)據(jù)類型dtype,如字符串到整型的轉(zhuǎn)換
判斷函數(shù)
NVL(expr1, expr2) -- 如果第一個參數(shù)為空則顯示第二個參數(shù),反之則顯示第一個參數(shù)。常用于非空判斷,如nvl(table1.name, '') <> ''
NVL2(expr1, expr2,expr3) -- 如果第一個參數(shù)為空則顯示第二個參數(shù),反之則顯示第三個參數(shù)
NULLIF(expr1, expr2) -- 如果第一個參數(shù)和第二個參數(shù)相等則返回空(NULL),否則返回第一個參數(shù)
Coalesce(expr1,expr2, expr3….exprn) -- 返回參數(shù)序列中第一個非空參數(shù)
解析函數(shù)
regexp_extract(string1,string pattern, int1) -- 正則表達式解析函數(shù)。將字符串string1按照正則表達式pattern的規(guī)則拆分,返回int1指定的字符。如regexp_extract(‘foothebar’, ‘foo(.*?)(bar)’, 1)=’the’,regexp_extract(‘foothebar’, ‘foo(.*?)(bar)’, 2)=’bar’
Size(map(
find_in_set(string1, string strList) -- 返回string1在strlist中第一次出現(xiàn)的位置,strlist是用逗號分割的字符串(集合)。如果沒有找string1,則返回0.
parse_url(string url_string, stringpartToExtract [, string keyToExtract]) --url解析函數(shù),partToExtract的有效值為:HOST,PATH, QUERY, REF, PROTOCOL, AUTHORITY, FILE, and USERINFO。如parse_url(‘
&k2=v2#Ref1′,‘QUERY’, ‘k1′)=’v1’
get_json_object(string json_string,string path) -- json解析函數(shù)。解析json的字符串json_string,返回path指定的內(nèi)容。如果輸入的json字符串無效,那么返回NULL。
行列轉(zhuǎn)換
concat_ws(sep, collect_set(col1)) -- 多行轉(zhuǎn)一列,以sep分隔符分隔。collect_set在無重復(fù)的情況下也可以collect_list()代替。collect_set()去重,collect_list()不去重
lateral view explode(split(col1, sep)) -- 一列轉(zhuǎn)多行。
-END-
本文為作者獨立觀點,不代表鳥哥筆記立場,未經(jīng)允許不得轉(zhuǎn)載。
《鳥哥筆記版權(quán)及免責(zé)申明》 如對文章、圖片、字體等版權(quán)有疑問,請點擊 反饋舉報
我們致力于提供一個高質(zhì)量內(nèi)容的交流平臺。為落實國家互聯(lián)網(wǎng)信息辦公室“依法管網(wǎng)、依法辦網(wǎng)、依法上網(wǎng)”的要求,為完善跟帖評論自律管理,為了保護用戶創(chuàng)造的內(nèi)容、維護開放、真實、專業(yè)的平臺氛圍,我們團隊將依據(jù)本公約中的條款對注冊用戶和發(fā)布在本平臺的內(nèi)容進行管理。平臺鼓勵用戶創(chuàng)作、發(fā)布優(yōu)質(zhì)內(nèi)容,同時也將采取必要措施管理違法、侵權(quán)或有其他不良影響的網(wǎng)絡(luò)信息。
一、根據(jù)《網(wǎng)絡(luò)信息內(nèi)容生態(tài)治理規(guī)定》《中華人民共和國未成年人保護法》等法律法規(guī),對以下違法、不良信息或存在危害的行為進行處理。
1. 違反法律法規(guī)的信息,主要表現(xiàn)為:
1)反對憲法所確定的基本原則;
2)危害國家安全,泄露國家秘密,顛覆國家政權(quán),破壞國家統(tǒng)一,損害國家榮譽和利益;
3)侮辱、濫用英烈形象,歪曲、丑化、褻瀆、否定英雄烈士事跡和精神,以侮辱、誹謗或者其他方式侵害英雄烈士的姓名、肖像、名譽、榮譽;
4)宣揚恐怖主義、極端主義或者煽動實施恐怖活動、極端主義活動;
5)煽動民族仇恨、民族歧視,破壞民族團結(jié);
6)破壞國家宗教政策,宣揚邪教和封建迷信;
7)散布謠言,擾亂社會秩序,破壞社會穩(wěn)定;
8)宣揚淫穢、色情、賭博、暴力、兇殺、恐怖或者教唆犯罪;
9)煽動非法集會、結(jié)社、游行、示威、聚眾擾亂社會秩序;
10)侮辱或者誹謗他人,侵害他人名譽、隱私和其他合法權(quán)益;
11)通過網(wǎng)絡(luò)以文字、圖片、音視頻等形式,對未成年人實施侮辱、誹謗、威脅或者惡意損害未成年人形象進行網(wǎng)絡(luò)欺凌的;
12)危害未成年人身心健康的;
13)含有法律、行政法規(guī)禁止的其他內(nèi)容;
2. 不友善:不尊重用戶及其所貢獻內(nèi)容的信息或行為。主要表現(xiàn)為:
1)輕蔑:貶低、輕視他人及其勞動成果;
2)誹謗:捏造、散布虛假事實,損害他人名譽;
3)嘲諷:以比喻、夸張、侮辱性的手法對他人或其行為進行揭露或描述,以此來激怒他人;
4)挑釁:以不友好的方式激怒他人,意圖使對方對自己的言論作出回應(yīng),蓄意制造事端;
5)羞辱:貶低他人的能力、行為、生理或身份特征,讓對方難堪;
6)謾罵:以不文明的語言對他人進行負面評價;
7)歧視:煽動人群歧視、地域歧視等,針對他人的民族、種族、宗教、性取向、性別、年齡、地域、生理特征等身份或者歸類的攻擊;
8)威脅:許諾以不良的后果來迫使他人服從自己的意志;
3. 發(fā)布垃圾廣告信息:以推廣曝光為目的,發(fā)布影響用戶體驗、擾亂本網(wǎng)站秩序的內(nèi)容,或進行相關(guān)行為。主要表現(xiàn)為:
1)多次發(fā)布包含售賣產(chǎn)品、提供服務(wù)、宣傳推廣內(nèi)容的垃圾廣告。包括但不限于以下幾種形式:
2)單個帳號多次發(fā)布包含垃圾廣告的內(nèi)容;
3)多個廣告帳號互相配合發(fā)布、傳播包含垃圾廣告的內(nèi)容;
4)多次發(fā)布包含欺騙性外鏈的內(nèi)容,如未注明的淘寶客鏈接、跳轉(zhuǎn)網(wǎng)站等,誘騙用戶點擊鏈接
5)發(fā)布大量包含推廣鏈接、產(chǎn)品、品牌等內(nèi)容獲取搜索引擎中的不正當(dāng)曝光;
6)購買或出售帳號之間虛假地互動,發(fā)布干擾網(wǎng)站秩序的推廣內(nèi)容及相關(guān)交易。
7)發(fā)布包含欺騙性的惡意營銷內(nèi)容,如通過偽造經(jīng)歷、冒充他人等方式進行惡意營銷;
8)使用特殊符號、圖片等方式規(guī)避垃圾廣告內(nèi)容審核的廣告內(nèi)容。
4. 色情低俗信息,主要表現(xiàn)為:
1)包含自己或他人性經(jīng)驗的細節(jié)描述或露骨的感受描述;
2)涉及色情段子、兩性笑話的低俗內(nèi)容;
3)配圖、頭圖中包含庸俗或挑逗性圖片的內(nèi)容;
4)帶有性暗示、性挑逗等易使人產(chǎn)生性聯(lián)想;
5)展現(xiàn)血腥、驚悚、殘忍等致人身心不適;
6)炒作緋聞、丑聞、劣跡等;
7)宣揚低俗、庸俗、媚俗內(nèi)容。
5. 不實信息,主要表現(xiàn)為:
1)可能存在事實性錯誤或者造謠等內(nèi)容;
2)存在事實夸大、偽造虛假經(jīng)歷等誤導(dǎo)他人的內(nèi)容;
3)偽造身份、冒充他人,通過頭像、用戶名等個人信息暗示自己具有特定身份,或與特定機構(gòu)或個人存在關(guān)聯(lián)。
6. 傳播封建迷信,主要表現(xiàn)為:
1)找人算命、測字、占卜、解夢、化解厄運、使用迷信方式治??;
2)求推薦算命看相大師;
3)針對具體風(fēng)水等問題進行求助或咨詢;
4)問自己或他人的八字、六爻、星盤、手相、面相、五行缺失,包括通過占卜方法問婚姻、前程、運勢,東西寵物丟了能不能找回、取名改名等;
7. 文章標題黨,主要表現(xiàn)為:
1)以各種夸張、獵奇、不合常理的表現(xiàn)手法等行為來誘導(dǎo)用戶;
2)內(nèi)容與標題之間存在嚴重不實或者原意扭曲;
3)使用夸張標題,內(nèi)容與標題嚴重不符的。
8.「飯圈」亂象行為,主要表現(xiàn)為:
1)誘導(dǎo)未成年人應(yīng)援集資、高額消費、投票打榜
2)粉絲互撕謾罵、拉踩引戰(zhàn)、造謠攻擊、人肉搜索、侵犯隱私
3)鼓動「飯圈」粉絲攀比炫富、奢靡享樂等行為
4)以號召粉絲、雇用網(wǎng)絡(luò)水軍、「養(yǎng)號」形式刷量控評等行為
5)通過「蹭熱點」、制造話題等形式干擾輿論,影響傳播秩序
9. 其他危害行為或內(nèi)容,主要表現(xiàn)為:
1)可能引發(fā)未成年人模仿不安全行為和違反社會公德行為、誘導(dǎo)未成年人不良嗜好影響未成年人身心健康的;
2)不當(dāng)評述自然災(zāi)害、重大事故等災(zāi)難的;
3)美化、粉飾侵略戰(zhàn)爭行為的;
4)法律、行政法規(guī)禁止,或可能對網(wǎng)絡(luò)生態(tài)造成不良影響的其他內(nèi)容。
二、違規(guī)處罰
本網(wǎng)站通過主動發(fā)現(xiàn)和接受用戶舉報兩種方式收集違規(guī)行為信息。所有有意的降低內(nèi)容質(zhì)量、傷害平臺氛圍及欺凌未成年人或危害未成年人身心健康的行為都是不能容忍的。
當(dāng)一個用戶發(fā)布違規(guī)內(nèi)容時,本網(wǎng)站將依據(jù)相關(guān)用戶違規(guī)情節(jié)嚴重程度,對帳號進行禁言 1 天、7 天、15 天直至永久禁言或封停賬號的處罰。當(dāng)涉及欺凌未成年人、危害未成年人身心健康、通過作弊手段注冊、使用帳號,或者濫用多個帳號發(fā)布違規(guī)內(nèi)容時,本網(wǎng)站將加重處罰。
三、申訴
隨著平臺管理經(jīng)驗的不斷豐富,本網(wǎng)站出于維護本網(wǎng)站氛圍和秩序的目的,將不斷完善本公約。
如果本網(wǎng)站用戶對本網(wǎng)站基于本公約規(guī)定做出的處理有異議,可以通過「建議反饋」功能向本網(wǎng)站進行反饋。
(規(guī)則的最終解釋權(quán)歸屬本網(wǎng)站所有)