返回顶部
首页 > 资讯 > 精选 >Go 中的 Apache Beam 左连接
  • 390
分享到

Go 中的 Apache Beam 左连接

go语言 2024-02-11 08:02:29 390人浏览 薄情痞子
摘要

PHP小编小新在这里给大家介绍一下Go语言中的Apache Beam左连接。Apache Beam是一种分布式数据处理框架,它提供了一种通用的编程模型,用于在不同的分布式数据处理引擎上

PHP小编小新在这里给大家介绍一下Go语言中的Apache Beam左连接。Apache Beam是一种分布式数据处理框架,它提供了一种通用的编程模型,用于在不同的分布式数据处理引擎上执行批处理和流处理任务。而左连接是一种常见的数据处理操作,它可以将两个数据集按照某个键进行关联,返回左侧数据集中的所有记录,以及与之匹配的右侧数据集中的记录。本文将详细介绍Go语言中如何使用Apache Beam进行左连接操作。

问题内容

有没有简单的方法可以使用 go 执行 2 个 pcollection 的左连接? 我发现 sql 连接仅在 java 中可用。

package main

import (
    "context"
    "flag"

    "GitHub.com/apache/beam/sdks/v2/go/pkg/beam"
    "github.com/apache/beam/sdks/v2/go/pkg/beam/log"
    "github.com/apache/beam/sdks/v2/go/pkg/beam/x/beamx"
)

type customer struct {
    CustID int
    FName  string
}

type order struct {
    OrderID int
    Amount  int
    Cust_ID int
}

func main() {

    flag.Parse()
    beam.Init()

    ctx := context.Background()

    p := beam.NewPipeline()
    s := p.Root()

    var custList = []customer{
        {1, "Bob"},
        {2, "Adam"},
        {3, "John"},
        {4, "Ben"},
        {5, "Jose"},
        {6, "Bryan"},
        {7, "Kim"},
        {8, "Tim"},
    }

    var orderList = []order{
        {123, 100, 1},
        {125, 30, 3},
        {128, 50, 7},
    }

    custPCol := beam.CreateList(s, custList)

    orderpcol := beam.CreateList(s, orderList)

    // Left Join custPcol with orderPCol
    // Expected Result
    // CustID | FName   |OrderID| Amount
    //     1  | Bob     |   123 | 100
    //     2  | Adam    |       |
    //     3  | John    |   125 | 100
    //     4  | Ben     |       |
    //     5  | Jose    |       |
    //     6  | Bryan   |       |
    //     7  | Kim     |   125 | 100
    //     8  | Tim     |       |

    if err := beamx.Run(ctx, p); err != nil {
        log.Exitf(ctx, "Failed to execute job: %v", err)
    }

}

我想加入这 2 个 pcollection 并执行进一步的操作。我看到了有关 cogroupbykey 的文档,但无法将其转换为普通 sql join 可以执行的格式。

对此有什么建议吗?

解决方法

尝试这样

type resulttype struct {
    custid  int
    fname   string
    orderid int
    amount  int
}

result := beam.pardo(s, func(c customer, iterorder func(*order) bool) resulttype {
    var o order

    for iterorder(&o) {
        if c.custid == o.cust_id {
            return resulttype{
                custid:  c.custid,
                fname:   c.fname,
                orderid: o.orderid,
                amount:  o.amount,
            }
        }
    }

    return resulttype{
        custid: c.custid,
        fname:  c.fname,
    }
}, custpcol, beam.sideinput{input: orderpcol})

或者如果您想使用 cogroupbykey ...

custWithKeyPCol := beam.ParDo(s, func(c customer) (int, customer) {
    return c.CustID, c
}, custPCol)

orderWithKeyPCol := beam.ParDo(s, func(o order) (int, order) {
    return o.Cust_ID, o
}, orderPCol)

resultPCol := beam.CoGroupByKey(s, custWithKeyPCol, orderWithKeyPCol)

beam.ParDo0(s, func(CustID int, custIter func(*customer) bool, orderIter func(*order) bool) {
    c, o := customer{}, order{}
    for custIter(&c) {
        if ok := orderIter(&o); ok {
            fmt.Println(CustID, c.FName, o.OrderID, o.Amount)
        }
        fmt.Println(CustID, c.FName)
    }
}, resultPCol)

以上就是Go 中的 Apache Beam 左连接的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: Go 中的 Apache Beam 左连接

本文链接: https://lsjlt.com/news/563400.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Go 中的 Apache Beam 左连接
    php小编小新在这里给大家介绍一下Go语言中的Apache Beam左连接。Apache Beam是一种分布式数据处理框架,它提供了一种通用的编程模型,用于在不同的分布式数据处理引擎上...
    99+
    2024-02-11
    go语言
  • Go 中的 Apache Beam ParDo 过滤器
    问题内容 我是一名 python 开发人员,但应该使用 go 制作数据流管道。 与 python 或 java 相比,我找不到那么多使用 go 的 apache beam 示例。 我有...
    99+
    2024-02-05
  • Apache Beam 从 Go 中的 PCollection 中选择前 N 行
    Apache Beam 是一个开源的分布式数据处理框架,它提供了一种统一的编程模型,可以在不同的批处理和流处理引擎上运行。最近,Apache Beam 的 Go SDK 中新增了一个非...
    99+
    2024-02-10
  • Beam中的IO连接器有什么用
    Beam中的IO连接器用于连接Beam设备和其他外部设备或系统,以实现数据的输入和输出。通过IO连接器,用户可以传输数据、控制设备或...
    99+
    2024-04-02
  • sql中左连接和左外连接的区别是什么
    左连接和左外连接的主要区别在于输出结果中来自左表的行:左连接:返回所有匹配左表和右表的行,不匹配的行被排除在外。左外连接:返回左表的所有行,对于匹配右表的行返回匹配值,对于不匹配的行返回...
    99+
    2024-05-10
  • MySQL的左连接、右连接、内连接
    一. 写法: 1.左连接:   SELECT student.Sno,Sname,Ssex,Sbirth,Sclass,Cno,Grade FROM student LEFT OUTER JOIN sc ON student.Sno...
    99+
    2023-10-18
    mysql sql
  • sql中左连接与右连接的区别
    sql 中左连接和右连接主要区别在于连接结果中优先显示哪个表的数据。左连接优先显示左表,若右表无匹配行则填充 null;右连接优先显示右表,若左表无匹配行则填充 null。 SQL 中...
    99+
    2024-05-10
  • sql中左连接和内连接的区别
    左连接与内连接的区别:左连接:返回左表所有行,即使右表中没有匹配的行;右表空值显示为 null。内连接:仅返回左表和右表中具有匹配行的行;若无匹配行,该行会被忽略。性能:左连接较慢,内连...
    99+
    2024-05-10
  • mysql中内连接,左连接和右连接的区别
    mysql 中内连接、左连接和右连接的区别在于:内连接只返回同时在两个表中匹配的行,而左连接返回左表所有行,包含匹配右表行,右连接返回右表所有行,包含匹配左表行。内连接语法:selec&...
    99+
    2024-04-29
    mysql
  • oracle中表的左右连接
    select tp.technic_product_code,       tp.technic_product_name,    &n...
    99+
    2024-04-02
  • sql中左连接的用法
    sql 左连接用于将两个表关联起来,即使右表中没有匹配的记录,也会返回左表的所有记录。用法:使用 left join 语法关联两个表。指定公共列用于连接两个表。左表中的所有记录都会返回,...
    99+
    2024-05-10
  • sql中的左连接和右连接的关系
    在 sql 中,左连接和右连接是两种联接类型:左连接优先显示左表中的所有行,匹配行显示右表数据,不匹配行为 null。右连接优先显示右表中的所有行,匹配行显示左表数据,不匹配行为 nul...
    99+
    2024-05-10
  • sql中的左连接和右连接的区别
    sql 中左连接和右连接的区别在于优先连接的表:左连接优先连接左表,而右连接优先连接右表。因此,当处理包含 null 值的表时,左连接将确保返回左表中的所有行,而右连接将确保返回右表中的...
    99+
    2024-05-10
  • sql中的左连接和右连接是什么
    sql 中的左连接和右连接是两种连接表的方式:左连接:保留左表所有行,即使右表没有匹配行,右表字段为空。右连接:保留右表所有行,即使左表没有匹配行,左表字段为空。 SQL 中的左连接和...
    99+
    2024-05-10
  • sql中左连接怎么写
    sql中的左连接会将左表的所有行与右表匹配的行联接,如果没有匹配行,左表行保留,右表值为空。适用于需要显示所有左表行、保留左表数据完整性等情况。例如,找出所有客户及其对应的订单时,可以使...
    99+
    2024-05-10
    数据丢失
  • mysql连接查询左连接,右连接,内连接的示例
    小编给大家分享一下mysql连接查询左连接,右连接,内连接的示例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、mysql常用连接INNER JOIN(内连接,或等值连接):获取两个表中...
    99+
    2024-04-02
  • MySQL中如何实现左连接与右连接
    这篇文章给大家介绍MySQL中如何实现左连接与右连接,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。表A记录如下: aID     &n...
    99+
    2024-04-02
  • MySQL中怎么实现左连接和右连接
    今天就跟大家聊聊有关MySQL中怎么实现左连接和右连接,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。以MySql为例。在MySQL数据库中建立两张数...
    99+
    2024-04-02
  • sql的四种连接——左外连接、右外连接、内连接、全连接
    一、内连接   满足条件的记录才会出现在结果集中。 二、 左外连接(left outer join,outer可省略) 左表全部出现在结果集中,若右表无对应记录,则相应字段为NULL   举例说明: 客户表: 订单表: 左外连接(...
    99+
    2023-09-10
    sql mysql 数据库
  • MySQL中左连接/右连接/等值连接有什么区别
    这篇文章给大家分享的是有关MySQL中左连接/右连接/等值连接有什么区别的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。从业以来,发现很多技术人员和同事向笔者或是在网络上咨询过LE...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作