• hive实例讲解实现in和not in子句


    目前hive不支持 in或not in 中包含查询子句的语法,所以只能通过left join实现。

    假设有一个登陆表login(当天登陆记录,只有一个uid),和一个用户注册表regusers(当天注册用户,字段只有一个uid),这两个表都包含一个字段,uid。

    in查询

    如果要查询当天登陆的注册用户,需要用in查询,hive sql如下:

    select login.uid from login left outer join regusers on login.uid=regusers.uid where regusers.uid is not null

    如果login表和regusers表按天分区,字段是dt,那么查询2013年1月1号当天登陆的注册用户,hive sql如下:

    select login.uid from login day_login left outer join 
       (select uid from regusers where dt='20130101') day_regusers
    on day_login.uid=day_regusers.uid where day_login.dt='20130101' and day_regusers.uid is not null

    not in查询

    如果要查询当天登陆的老用户(这里假设非当天注册用户就是老用户),需要用not in查询,hive sql如下:

    select login.uid from login left outer join regusers on login.uid=regusers.uid where regusers.uid is null;

    如果login表和regusers表按天分区,字段是dt,那么查询2013年1月1号当天登陆的老用户,hive sql如下:

    select login.uid from login day_login left outer join 
       (select uid from regusers where dt='20130101') day_regusers
    on day_login.uid=day_regusers.uid where day_login.dt='20130101' and day_regusers.uid is null;
  • 相关阅读:
    2019 春第1次课程设计实验报告
    2019春第十二周作业
    2019春第十一周作业
    2019春第十周作业
    关于Vmvare虚拟机中Linux系统不能全屏的问题
    My algorithmic road
    段错误
    python人生如初见之初见yield
    网络爬虫requests-bs4-re-1
    The First Python man in Github
  • 原文地址:https://www.cnblogs.com/ggjucheng/p/2842855.html
Copyright © 2020-2023  润新知