当前位置: 首页 > news >正文

怎样注册网站域名深圳建网页

怎样注册网站域名,深圳建网页,石家庄电子商城网站建设,效果图制作教程前言 行专列,列转行是数开不可避免的一步,尤其是在最初接触Hive的时候,看到什么炸裂函数,各种udf,有点发憷,无从下手,时常产生这t怎么搞,我不会啊? 好吧&#xff…

前言       

         行专列,列转行是数开不可避免的一步,尤其是在最初接触Hive的时候,看到什么炸裂函数,各种udf,有点发憷,无从下手,时常产生这t怎么搞,我不会啊?

        好吧,真正让你成长的,还得是甩给你一个需求,然后你自己绞尽脑汁的去实现。

列转行

SparkSQL中Hive_STACK函数列转行原理 

        Hive中的STACK函数,可以将多个列转换为多行,每行包含两个值:第一个值是指定的列名,第二个值是该列的值。

        stack(INT n, v1, v2, ..., vk)            

        -----把M列转换成N行,每行有M/N个字段,其中n必须是个常数

生产中的案例

        我以我在sparksql开发过程中遇到的实例为例,简单介绍一下用法。

        给一frame表:我这里只拿出一写字段和数据,不过足够演示了这个函数的用法了


+--------+--------+--------+--------+--------+
| fzl0000| fzl0100| fzl0200| max_fzl|   fzl  |
+--------+--------+--------+--------+--------+
|   0.9  |   0.8  |   0.7  |   0.6  |   0.5  |
+--------+--------+--------+--------+--------+

我要将上面的几列数据进行列转行,比较粗暴

HiveSQL代码

SELECT stack(4,'fzl0000', fzl0000,'fzl0100', fzl0100,'fzl0200', fzl0200,'max_fzl', max_fzl) AS (stat_time, mfzl)
FROM frame;

丢到集群跑程序然后我们得到的结果就出来

+--------------+------+
|stat_time     | mfzl  |
+--------------+------+
|   fzl0000    | 0.9  |
|   fzl0100    | 0.8  |
|   fzl0200    | 0.7  |
|   max_fzl    | 0.6  |
+--------------+------+

        注意,hue是不能直接跑这个代码的,impala也不行,会报错,不知道你的会不会报错。所以还是老老实实写spark程序搞吧。

        Spark代码

// 使用PIVOT函数进行列转行操作
val df_pivot = df.groupBy().pivot("stat_time").agg(expr("first(mfzl)"))

        你也可以在stack函数里头做一些函数操作比如一些转换啊啥的,自己去摸索一下吧。

行转列

        还是以上面的数据为例,行转列列转行就像我们学过的高数中的矩阵转置,也就是线性代数中的矩阵,这个可以了解一下,计算机底层皆是数学。

SparkSQL中Hive_PIVOT函数行转列原理

        一、PIVOT函数是Spark SQL中的一个聚合函数,用于将一列的值转换为多列。它将行数据中的某一列作为列名,将该列对应的值作为新的列的值,并将其他列的值保持不变,完成咱们得行转列操作,下图是一个很好的例子。

                                        图片来源:https://juejin.cn/post/6844903619171631117

    二、PIVOT函数接受三个参数:要进行聚合的列,要作为新列的列名,以及可选的要聚合的函数,这里头要聚合的列是把可能有重复的列聚合成一列。比如上图中多次重复出现的c1,c2,c3,我们要保证唯一值进行聚合,不能出现重复的列。

        dataFrame数据

+--------------+------+
|stat_time     | mfzl  |
+--------------+------+
|   fzl0000    | 0.9  |
|   fzl0100    | 0.8  |
|   fzl0200    | 0.7  |
|   max_fzl    | 0.6  |
+--------------+------+

行转列


+--------+--------+--------+--------+--------+
| fzl0000| fzl0100| fzl0200| max_fzl|   fzl  |
+--------+--------+--------+--------+--------+
|   0.9  |   0.8  |   0.7  |   0.6  |   0.5  |
+--------+--------+--------+--------+--------+

Spark代码

val transformedDF = df.groupBy().pivot("stat_time").agg(first("mfzl"))

部分参考文章

1、行转列参考文章:https://juejin.cn/post/6844903619171631117,这篇文章很好,讲解的条理清晰,忍不住推荐一波!

http://www.yayakq.cn/news/993089/

相关文章:

  • 网站怎么分类中职网站建设与管理专业
  • 建一个淘宝客网站要多少钱网站建设是怎么赚钱的
  • 仙游县建设局网站佛山营销网站设计
  • 网上免费网站的域名快速建站全流程详细指导手册
  • 福州集团网站建设用php做图书管理网站
  • 杭州软件开发公司网站龙凤网站建设云聚达
  • 免费做简易网站门户网站推广方案
  • 做柜子好的设计网站门户网站定制开发
  • 收录网站查询洱源网站建设
  • 网站开发怎么报价单遵义住建局查询网站
  • 农产品网站的品牌建设网站建设模板套用
  • 网站运营需要++做哪些工作网站认证是什么
  • 学网站建设需要多长时间免费网站制作 优帮云
  • 组建网站开发团队看房子建设进度的网站
  • 成都外贸建站个人网站做企业网站
  • 北郊网站建设公司金融企业网站php源码
  • 建网站需要多少钱东莞保安公司招聘电话
  • 最牛的科技网站建设下载站用什么网站系统
  • 艺术视频手机网站可以做吗企业网站开发用什么好
  • 北京市基础建设质量监督局网站长沙专业网站制作
  • 微信公众号网站建设费哪里可以兼职答题
  • 推广公司新形象的营销支出南京seo排名外包
  • 郑州做网站_郑州免费建站免费邮箱登录入口
  • 网站建设价格表卢氏县住房和城乡建设局网站
  • 网站不备案可以做淘宝联盟吗十六局集团门户网
  • 网站表单模板专业网页制作加盟
  • 网站商城注意事项互联网是什么
  • 网站建设合同拟写公司网站换服务器怎么做
  • 怎么样管理网站wordpress 4.5 中文404
  • 多少钱做网站网络游戏营销策略