首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Rhino-Etl中链接InputOperations

在Rhino-Etl中链接InputOperations
EN

Stack Overflow用户
提问于 2013-11-19 02:41:37
回答 1查看 495关注 0票数 3

我最近刚刚开始将Rhino-Etl用于非常简单的ETL过程,并取得了巨大的成功。我现在有一个稍微复杂的场景要处理,我没有发现ConventionInputCommandOperation的行为方式与我预期的一样。

我做了一个非常简单的例子来说明我想要做的事情。基本上,我涉及两个系统,直到我第一次查询系统1,我才知道我想从系统2得到什么。我认为在另一个InputOperation之后立即注册一个InputOperation的行为就像一个循环。这样,操作1中的每一行都将提供给操作2。下面的代码失败,并显示“无法执行操作DetailReader:必须声明标量变量@PlanetAbbrv”。所以我的问题是,当输入操作依赖于之前的输入操作时,您打算如何处理这种情况?

谢谢,布赖恩

代码语言:javascript
复制
using System;
using Rhino.Etl.Core;
using Rhino.Etl.Core.ConventionOperations;

namespace ETLTest
{
    class Program
    {
        static void Main()
        {
            new MainProcess().Execute();
            Console.ReadLine();
        }
    }

    public class MainProcess : EtlProcess
    {
        protected override void Initialize()
        {
            Register(new MainReader());
            Register(new DetailReader());
        }

        protected override void PostProcessing()
        {
            foreach (var exception in GetAllErrors())
            {
                throw exception;
            }
        }
    }

    public class MainReader : ConventionInputCommandOperation
    {
        public MainReader() : base("Galactic1")
        {
            Command = @"select * from Planet";
        }
    }

    public class DetailReader : ConventionInputCommandOperation
    {
        public DetailReader() : base("Galactic2")
        {
            Command = @"select * from Delivery where DeliveryPlanetAbbrv = @PlanetAbbrv";
        }
    }
}
EN

回答 1

Stack Overflow用户

发布于 2014-01-03 23:46:22

您需要让DetailReader选择所有行(去掉where操作)。然后使用JoinOperation将详细信息与主要信息进行匹配。

代码语言:javascript
复制
Register(new JoinPlanets()
                     .Right(new MainReader())
                     .Left(new DetailReader()));


public class JoinPlanets: JoinOperation
{
    protected override Row MergeRows(Row leftRow, Row rightRow)
    {
        Row row = leftRow.Clone();
        foreach (var column in leftRow.Columns)
            row[column] = leftRow[column];
        return row;
    }

    protected override void SetupJoinConditions()
    {
        FullOuterJoin.Left("PlanetAbbrv")
                     .Right("DeliveryPlanetAbbrv");
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20055307

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档