米利唐_后腰_乌克兰足球超级联赛_中国竞彩欧赔 - 足球竞彩分析

集團官網
  • 國家級全民數字素養與技能培訓基地
  • 河南省第一批產教融合型企業建設培育單位
  • 鄭州市數字技能人才(碼農)培養評價聯盟

Hive中怎樣創建內部數據表和外部數據表?

編輯:云和數據 日期:2023-03-02 17:41

數據表是存儲數據的基本單位,Hive數據表主要分為內部表(又叫托管表)和外部表,以內部表和外部表為基礎可以創建分區表或分桶表,即內/外部分區表或內/外部分桶表。接下來,針對內部表和外部表進行詳細講解。

默認情況下,內部表和外部表的數據都存儲在Hive配置文件中參數hive.metastore.warehouse.dir指定的路徑。它們的區別在于刪除內部表時,內部表的元數據和數據會一同刪除;而刪除外部表時,只刪除外部表的元數據,不會刪除數據。外部表相對來說更加安全,數據組織更加靈活并且方便共享源數據文件。

CREATE?TABLE?IF?NOT?EXISTShive_database.managed_table(staff_id?INT?COMMENT?"This?is?staffid",staff_name?STRING?COMMENT?"This?is?staffname",salary?FLOAT?COMMENT?"This?is?staff?salary",hobby?ARRAY?CONMENT?"This?is?staff?hobby",deduct(hps?MAP?COMMENT?"This?is?staff?deduction",address?STRUCT?COMMENT?"This?is?staff?address")ROW?FORMAT?DELIMITEDFIELDS?TERMINATED?BY?','COLLECTION?ITEMS?TERMINATED?BYMAP?KEYS?TERMINMTED?BY??':'LINES?TERMINATED?BY?'\n'STORED?AS?textfileTBLPROPERTIES("comment"="This?is?a?managed?table");

上述命令中,指定ROW FORMAT DELIMITED子句使用Hive內置的Serde,自定義字段(FIELDS)分隔符為“,”;自定義集合元素(COLLECTION ITEMS)的分隔符為“_”;自定義MAP(MAP KEYS)的鍵值對分隔符為“:”;自定義行(LINES)分隔符為\n。

(2)創建外部表external_table的命令如下。

CREATE?TABLE?IF?NOT?EXISTShive_database.managed_table(staff_id?INT?COMMENT?"This?is?staffid",staff_name?STRING?COMMENT?"This?is?staffname",salary?FLOAT?COMMENT?"This?is?staff?salary",hobby?ARRAY?CONMENT?"This?is?staff?hobby",deduct(hps?MAP?COMMENT?"This?is?staff?deduction",address?STRUCT?COMMENT?"This?is?staff?address")ROW?FORMAT?DELIMITEDFIELDS?TERMINATED?BY?','COLLECTION?ITEMS?TERMINATED?BYMAP?KEYS?TERMINMTED?BY??':'LINES?TERMINATED?BY?'\n'STORED?AS?textfileTBLPROPERTIES("comment"="This?is?a?managed?table");

上述命令中,通過在CREATETABLE句式中指定EXTERNAL子句創建外部表。創建外部表時通常配合LOCATION子句指定數據的存儲位置,便于數據的維護與管理。

相關內容

搶先一步 鴻蒙(HarmonyOS)應用開發者高級認證 免費考! 適合人群計算機相關專業在校生(技師、中職、高職、本科、研究生)對鴻蒙(HarmonyOS)有興趣的非計算機相關專業在校生目前正在從事移動應用的開發者目前正在從事計算機行業相關的人計算機專業高校老師所有對鴻蒙(HarmonyOS)有興趣的人 培訓方案掌握鴻蒙的核心概念和端云一體化開發、... 什么是Java的多態性(polymorphism)?它有哪些不同的形式? 多態性是Java面向對象編程的一個重要概念,它允許不同的對象以一致的方式響應同一個方法調用,具體表現為對象在運行時可以表現出多個不同的形態。多態性主要有兩種不同的形式:編譯時多態性(靜態多態性)和運行時多態性(動態多態性)。1. 編譯時多態性(靜態多態性):   ... 如何學習和搭建Hadoop開發環境? Hadoop是大數據處理領域的重要平臺,能夠處理和分析大量數據。為了有效地利用Hadoop,我們需要學習其基礎知識,并正確搭建開發環境。下面是詳細的學習和搭建指南。一、學習Hadoop基礎掌握基礎概念和原理Hadoop主要由HDFS和MapReduce兩部分組成。HDFS是分布式文件系統,Ma... UI 設計學習如何進階成為高手 我總結了六種方法,幫助你走出舒適區,提高技能,成長為自信且經驗豐富的UI設計高手一位經驗豐富的 UI 設計師,往往十分看中應用程序界面的吸引力和視覺刺激,確保滿足用戶期望和需求。但是,如果你已經在 UI 設計圈摸爬滾打多年,仍然沒有出色的作品,那你極有可能是因為陷入了一個舒適圈,UI技能一直原... 在Java中Executor和Executors的區別? 在Java中,Executor和Executors都與線程池和并發執行有關,但它們是不同的概念和類。1.ExecutorExecutor是一個接口,位于java.util.concurrent包中,用于表示一個執行任務的執行器。它只定義了一個方法:void execute(Runnable c... String類型的常見命令有哪些? String類型,也就是字符串類型,是Redis中最簡單的存儲類型。其value是字符串,不過根據字符串的格式不同,又可以分為3類:string是普通字符串,int整數類型,可以做自增、自減操作,float浮點類型,可以做自增、自減操作。String的常見命令有:SET:添加或者修改已經存在的...