在hive中的模糊查询,删除表,删除不符合条件的数据

1.模糊查询

类似:
在MYSQL里面我们可以这样的执行SQL

select a.Community,a.PID,b.spidertime,b.comm,b.showings,b.room from lianjia_list a ,RentHouse_lianjia b where a.site = 7 and b.city='北京'  and  b.comm like %a.Community%;

不行我们可以这样
select a.Community,a.PID,b.spidertime,b.comm,b.showings,b.room from lianjia_list a ,RentHouse_lianjia b where a.site = 7 and b.city='北京'  and  b.comm like {%a.Community%};

或者类似其他的我们可以直接%你要匹配的字段% 


但是在hive里面不行,有人说这事一个BUG,并自定义UDF去完成这个操作,因为他转义了!

今天我试了很多种方法,让我头疼了也很久

select a.Community,a.PID,b.spidertime,b.comm,b.showings,b.room from lianjia_list a ,RentHouse_lianjia b where a.site = 7 and b.city='北京'  and  b.comm like concat('%',a.Community,'%');

发现,我们这样用拼接字符串的方式来实现模糊匹配,大家试试吧!

自己测试 好使!!!

select count(*) from finallyresult where ds like concat(20181227,'%');


转自:https://www.cnblogs.com/tnsay/p/5752616.html

但是经自己测试 原始方法也正确!!!!


select count(*) from finallyresult where ds like '20181227%';

具体根据实际情况来使用like还是substring(ds,1,8)

2.删除hive表操作

drop table if exists 表名;

3.删除不符合条件的数据

insert overwrite table 表名 select * from 表名 where xxxxx;
//注意!!! xxxx是你需要保留的数据的查询结果

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值