加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

.net – SSIS中的Hyperion Essbase连接

发布时间:2020-12-12 13:08:56 所属栏目:百科 来源:网络整理
导读:如何让SSIS连接到Oracle Hyperion Essbase多维数据集以将其用作数据源?谷歌搜索返回以下内容: 一个similar question被问到一个特定的版本没有真正的答案,除了“第三方工具可以做到”. A microsoft SSIS connectors wiki表示您可以通过Star Analytics执行此
如何让SSIS连接到Oracle Hyperion Essbase多维数据集以将其用作数据源?谷歌搜索返回以下内容:

>一个similar question被问到一个特定的版本没有真正的答案,除了“第三方工具可以做到”.
> A microsoft SSIS connectors wiki表示您可以通过Star Analytics执行此操作.
>从SQL Server 2005 SP2开始,Reporting Services(SSRS)具有数据源连接.此产品功能似乎没有转换为SSIS的任何对象.一位博主建议,在Hyperion开始支持连接到SQL Server 2005 SSAS多维数据集之前,这可能是在Oracle收购Hyperion之前作为交换条件安排完成的.
>根据@billinkc,他使用直接.NET连接到它.一点点挖掘返回Hyperion Application Builder .NET(HAB.NET).起初,这似乎是一个很有前途的解决方案,但事实证明该产品已经停止了11.1.3版本. @billinkc现在也提供了一个代码示例,所以我将测试它,看看是否有效.

除了许可成本过高的Star Analytics服务器产品(对我来说),还有其他解决方案吗?

我没有听说过HAB.NET,但是我发现了1.相反,我刚刚在.NET中进行了简单的连接测试,如下所示.我已经修改了一下以使用DTS的东西.显然,你需要定义你的缓冲区列和类型,但希望这可以让你通过hyperion的东西.

要访问Microsoft.AnalysisServices.AdomdClient类,请添加对ADOMD.NET的引用并保存所有内容.然后下面的代码将正常运行.

using System;
using System.Data;
using Microsoft.SqlServer.Dts.Pipeline.Wrapper;
using Microsoft.SqlServer.Dts.Runtime.Wrapper;

using Microsoft.AnalysisServices.AdomdClient;

public class ScriptMain : UserComponent
{
    public override void CreateNewOutputRows()
    {
        string connectionString = string.Empty;
        connectionString = "Provider=MSOLAP;Data Source=http://hyperion00:13080/aps/XMLA; Initial Catalog=GrossRev;User Id=Revenue;Password=ea$yMon3y;";
        string query = "SELECT ...";
        AdomdDataReader reader = null;
        try
        {
            using (AdomdConnection conn = new AdomdConnection(connectionString))
            {
                conn.Open();
                using (AdomdCommand cmd = new AdomdCommand(query,conn))
                {
                    reader = cmd.ExecuteReader();

                    while (reader.Read())
                    {
                        // Replace Console.WriteLine with assignment of
                        // Output0Buffer.AddRow();
                        // Output0Buffer.column = (stronglyTyped) reader[i]
                        Console.WriteLine(reader.GetString(0));
                        Console.WriteLine(reader.GetString(1));
                    }
                    Console.WriteLine("fin");
                }

            }
        }
        catch (Exception ex)
        {
            Console.WriteLine(ex);

            throw;
        }
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读