使用 lateral view explode(col1)后行数变少了,bug排查

问题复现

查询该表结果为100行

select count(1) as cnt

from (

select distinct a,b,c

from pageAds

)

查询下表条数为90行

select count(1) as cnt

from (

select distinct a,b,c

from pageAds

)

lateral view explode(split(a,',')) adTable as d

思考:第二条语句只比第一个多一个炸裂函数,炸裂函数的作用是将数据炸开变成多行数据,为什么还会条数变少了呢?

经过各种资料查找,数据探索,发现当字段是空时,不会形成新的一行,而是会把这条数据过滤掉

例如有20条a是空,那如果a都没有被分割,那就会生成80条数据,我这个a有被分割,所以生成了90条数据

注意:以后用这个的时候一定要探索好分割字段,当有空的时候提前把空值处理好,例如提前赋默认值

如下

select count(1) as cnt

from (

select distinct coalesce (case when a='' then ','

else a

end ,

',') as a

,b,c

from pageAds

)

lateral view explode(split(a,',')) adTable as d

相关推荐
r***934819 小时前
PostgreSQL版本选择
数据库·postgresql
半路_出家ren19 小时前
Tomcat下配置woniusales
java·数据库·mysql·网络安全·adb·tomcat·firewalld
g***727019 小时前
mysql之联合索引
数据库·mysql
红树林0719 小时前
渗透测试之sql注入--盲注
数据库·sql·安全·web安全
智能化咨询19 小时前
(66页PPT)高校智慧校园解决方案(附下载方式)
大数据·数据库·人工智能
hhwyqwqhhwy19 小时前
linux 设备树内容和plateform_device
java·linux·数据库
浪漫血液&19 小时前
索引为什么用B+树而不是B树
数据结构·数据库·b树·b+树
2的n次方_19 小时前
openGauss压力测试:性能、稳定性与AI能力的全面探索
数据库·人工智能·压力测试
热心市民小刘050519 小时前
数据库基础知识点总结
数据库·oracle
Chloeis Syntax20 小时前
MySQL初阶学习日记(3)--- 增查改删(CRUD)
数据库·学习·mysql