• <noscript id="e0iig"><kbd id="e0iig"></kbd></noscript>
  • <td id="e0iig"></td>
  • <option id="e0iig"></option>
  • <noscript id="e0iig"><source id="e0iig"></source></noscript>
  • hive 導出數據之一列多行,轉為一行多列

    標簽: hive  提取數據  一行多列  類似行列轉換

    需求:提取數據
    說明:原數據是一列多行,需要轉化為一行多列

    待查詢表為:temp_05

    hive> desc temp_05;
    OK
    data_dt                 string
    zhanghao                string
    booking_time_final      string
    sign                    string
    hname                   string
    channel                 string
    min_price_weight        string
    Time taken: 0.04 seconds, Fetched: 7 row(s)

    待查詢數據為:

    hive>
        > select
        >   booking_time_final,data_dt,min_price_weight
        > from temp_05 where hname like'%兆龍%' and booking_time_final like '%2018-02%' and channel='5'
        > ;

    待查詢數據如圖:
    原始數據如圖:
    需要提取的數據表頭如下:

    預定日期 昨日價格 前天價格
    2018-02-01
    2018-02-02
    2018-02-03
    2018-02-04

    可用提數 SQL

    select
      booking_time_final,
      concat_ws('',collect_set(if(data_dt='20180129',min_price_weight,''))) a,
      concat_ws('',collect_set(if(data_dt='20180130',min_price_weight,''))) a2
    from temp_05
    where hname like'%兆龍%' and booking_time_final like '%2018-02%' and channel='5' 
    group by booking_time_final ;

    數據如圖:
    數據如圖:


    以下為嘗試過程

    hive>
        > select
        >   if(data_dt='20180129' and booking_time_final='2018-02-01',min_price_weight,'') a,
        >   if(data_dt='20180130' and booking_time_final='2018-02-01',min_price_weight,'') a2
        > from temp_05
        > where hname like'%兆龍%' and channel='5'
        > ;
    OK

    數據如圖:
    數據如圖:

    hive>
        > select
        >     data_dt,booking_time_final,
        >   if(data_dt='20180129' and booking_time_final='2018-02-01',min_price_weight,'') a,
        >   if(data_dt='20180130' and booking_time_final='2018-02-01',min_price_weight,'') a2
        > from temp_05
        > where hname like'%兆龍%' and channel='5'
        > ;

    數據如圖:
    數據如圖

    hive> select
        >   booking_time_final,
        >   if(data_dt='20180129',min_price_weight,'-') a,
        >   if(data_dt='20180130',min_price_weight,'-') a2
        > from temp_05
        > where hname like'%兆龍%' and booking_time_final like '%2018-02%' and channel='5'
        > ;

    數據如圖:
    數據如圖

    hive>
        > select
        >   booking_time_final,
        >   collect_set(if(data_dt='20180129',min_price_weight,'-')) a,
        >   collect_set(if(data_dt='20180130',min_price_weight,'-')) a2
        > from temp_05
        > where hname like'%兆龍%' and booking_time_final like '%2018-02%' and channel='5'
        > group by booking_time_final
        > ;

    數據如圖:
    數據如圖:

    版權聲明:本文為dear_csdn原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接和本聲明。
    本文鏈接:https://blog.csdn.net/dear_csdn/article/details/79220435

    智能推薦

    用Python實現校園通知更新提醒

    前言 這個項目實已經在一個月前已經完成了,一直都想寫一篇博客來總結這個過程中遇到的一些問題。但最近一個月來都比較忙,所以一直拖到了現在。 首先說說起因吧,我沒事的時候,總喜歡依次點開學校主頁、教務處、圖書館以及學院的網站,看看有沒有什么新通知,雖然大多與我無關。恰逢最近正在學Python,經常聽到別人說用Python寫爬蟲很簡單,但自己尚未接觸過爬蟲。于是抱著試一試的心態看了幾篇關于Python爬...

    spring_ioc相關_第一章

    1 spring是一站式框架,在javaee的三層結構中,每一層都提供不提并的解決技術 web層:springMVC service層:spring的ioc dao層:spring的jdbcTemplate 2 javaee為避免兩個類之間出現耦合,則把對象的創建交給spring進行管理,spring的ioc操作:(1)ioc的配置文件方式;(2)ioc注解方式 3 ioc的底層原理使用技術(1)...

    【Python+OpenCV】視頻流局部區域像素值處理-一種特征提取方法

    參考我之前寫的處理圖片的文章:Python+OpenCV實現【圖片】局部區域像素值處理(改進版) 開發環境:Python3.6.0 + OpenCV3.2.0 任務目標:攝像頭采集圖像(例如:480*640),并對視頻流每一幀(灰度圖)特定矩形區域(480*30)像素值進行行求和,得到一個480*1的數組,用這480個數據繪制條形圖,即在逐幀采集視頻流并處理后“實時”顯示采...

    JavaWeb——【前端】——注冊頁面

    頁面效果 實現代碼 注意事項 主要使用的bootstrap樣式 如果想引用,不要直接復制,沒用的。 先介紹下所引用的文件: boostrap的js、bootstrap的css、jquery的js、以及自己編寫的register.css。 因為博主用的thymeleaf語法,所以有th符號。 若要使用時,根據個人情況導入相應的依賴。...

    網站HTTP升級HTTPS完全配置手冊

    本文由葡萄城技術團隊于博客園原創并首發 轉載請注明出處:葡萄城官網,葡萄城為開發者提供專業的開發工具、解決方案和服務,賦能開發者。 今天,所有使用Google Chrome穩定版的用戶迎來了v68正式版首個版本的發布,詳細版本號為v68.0.3440.75,上一個正式版v67.0.3396.99發布于6月13日,自Chrome 68起,當在加載非HTTPS站點時,都會在地址欄上明確標記為&ldqu...

    猜你喜歡

    echarts 自定義儀表盤設置背景圖片

    echarts儀表盤 使用插件 vue-echarts 代碼示例 HTML部分 js部分 效果圖...

    RT-Thread Studio部分定時器時鐘不正確的解決方案

    在昨天的RT-Thread Studio硬件定時器hwtimer在stm32f411上的使用筆記中,遇到了部分定時器速度想象中和實際不一致的情況,具體表現在定時器2、3、4、5、9、10、11都正常,但定時器1要快一倍。 仔細查看代碼,找到了原因。 因為代碼使用的是工程是直接生成的時鐘代碼,實際的時鐘頻率是這樣的: 而實際的定時器時鐘配置代碼如下: 針對F411,去掉其中的宏定義是這樣的: 這里說...

    symfony學習筆記之模板渲染-----twig總結

    參考:https://blog.csdn.net/liebert/article/details/77414217 目錄 一、模板引擎工作原理 二、Twig模板引擎 1.運行環境要求 2.基本API用法 3.設計模板 (1)變量輸出         a.全局變量         b.設置變量 (2)...

    小甲魚Python3學習筆記之第六講(僅記錄學習)

    第六講:python之常用操作符 一、知識點: 0.算術運算符:+,-,*,/,%(取模,即求余數),**(冪運算),//(地板除法,取整除,返回商的整數部分) 備注:①雙斜杠 // 除法總是向下取整。             ②從符點數到整數的轉換可能會舍入也可能截斷,建議使用math....

    Java 習題 (21)

    題目: 寫一個程序,打印從1 到 100 的值。 解答: 答案如下: (只是截取結果一部分) 如果覺得不錯,就用點贊或者關注來取代五星好評吧!...

    精品国产乱码久久久久久蜜桃不卡