C#应用访问Microsoft SQL Server 2005分析服务

原创 2006年05月17日 09:14:00

一、前言

1、运行环境

Windows 2003 Server Enterprise Edition with Service Pack 1

Microsoft SQL Server 2005 with Service Pack 1(包含Analysis Service)

Visual Studio 2005 Team Suite

2、本文使用Microsoft SQL Server 2000下也可使用的ADOMD .NET访问分析服务。

二、目标

查询分析服务数据转换为DataTable形式,在GridView中显示。

三、实现

通过Adomd .NET访问分析服务。通过MDX查询语言查询数据。

1、  ADO .NET一样,ADOMD .NET也主要有在线数据读取器AdomdDataReader和离线数据集(类似DataSet) CellSet

2、  访问数据的步骤为:建立连接->打开连接->建立AdomdCommand ->得到CellSet->关闭连接->CellSet转化为DataTable或将数据绑定到对应的饼图等统计图控件

3、  代码片断

l         打开连接,连接到分析服务

        public void OpenConnection()

        {

            if (_connection != null)

                if (_connection.State == ConnectionState.Closed)

                    _connection.Open();

        }

l          获得CellSet数据对象

        public CellSet ExecuteCellSet(string queryString)

        {

            OpenConnection();

 

            AdomdCommand command = _connection.CreateCommand();

 

            command.CommandText = queryString;

           

            CellSet cellSet = command.ExecuteCellSet();

           

            CloseConnection();

 

            return cellSet;

        }

l          CellSet数据对象转换为DataTable对象

        public DataTable ToDataTable(CellSet cs)

        {

            DataTable dt = new DataTable();

            DataColumn dc = new DataColumn();

            DataRow dr = null;

 

            //第一列:必有为维度描述(行头)

            dt.Columns.Add(new DataColumn("Description"));

 

            //生成数据列对象

            string name;

 

            foreach (Position p in cs.Axes[0].Positions)

            {

                dc = new DataColumn();

                name = "";

                foreach (Member m in p.Members)

                {

                    name = name + m.Caption + " ";

                }

 

                dc.ColumnName = name;

                dt.Columns.Add(dc);

            }

 

            //添加行数据

            int pos = 0;

 

            foreach (Position py in cs.Axes[1].Positions)

            {

                dr = dt.NewRow();

 

                //维度描述列数据(行头)

                name = "";

                foreach (Member m in py.Members)

                {

                    name = name + m.Caption + "/r/n";

                }

                dr[0] = name;

 

                //数据列

                for (int x = 1; x <= cs.Axes[0].Positions.Count; x++)

                {

                    dr[x] = cs[pos++].FormattedValue;

                }

 

                dt.Rows.Add(dr);

            }

 

            return dt;

        }

5、程序调用

    BaseComponent.Data.SqlAnalysisService sa

        = new SqlAnalysisService("Data Source=localhost;Catalog=LibraryStat");

 

    protected void Page_Load(object sender, EventArgs e)

    {

        StringBuilder sb=new StringBuilder();

 

        sb.Append("with ");

        sb.Append(" set [AllCount] as '[图书分销 订单].[层次结构].[单位].[安徽大学     图书馆].Children'");

        sb.Append(" Member [图书分销 订单].[层次结构].[单位].[安徽大学     图书馆].[合计] as 'aggregate([AllCount])'");

        sb.Append(" Member [所占订单数百分比] as '[订单数量]/([订单数量],[图书分销 订单].[层次结构].[单位].[安徽大学     图书馆].[合计])',format_string='#.00%'");

        sb.Append(" select {[Measures].[订单数量],[Measures].[储运数量],[Measures].[原始数量],[所占订单数百分比]} on columns,");

        sb.Append(" {[图书分销 订单].[层次结构].[单位].[安徽大学     图书馆].Children} on rows");

        sb.Append(" from [图书馆统计]");

 

        DataTable dt = sa.GetDataTable(sb.ToString());

 

        gv.DataSource = dt;

        gv.DataBind();

    }

gv为一个GridView对象。除了查询语句不同,数据绑定是一样的,因为已经转换为DataTable了。

四、备注

命名空间:Microsoft.AnalysisServices.AdomdClient

程序集文件:Microsoft.AnalysisServices.AdomdClient.dllMicrosoft SQL Server 20059.0版;Microsoft SQL Server 20008.0版)

AdomdClient当然有AdomdServer,分析服务也包含了存储过程和CLR的存储过程。

五、后记

l         理论上本例也可以在Microsoft SQL Server 2000下运行。但是我的同事在WebForm下应用时出现错误。

l         在微软推出Microsoft SQL Server 2005之后,微软又为分析服务提供了多种访问方式。

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

T-SQL 编程与应用----学习笔记一[Microsoft SQL Server 2005]

1.有效标识符 @开头的标识符表示这是一个局部变量或是一个函数的参数@@全局变量#开头的标识符表示这是一个临时表或是一个存储过程##开头的标识符表示这是一个全局的临时数据库对象2.注释(1)多行注释/...

SQL SERVER数据库开发之存储过程应用---[Microsoft Sql Server 2005]

可能有不少朋友使用SQL SERVER做开发也已经有段日子,但还没有或者很少在项目中使用存储过程,或许有些朋友认为根本没有必要使用存储过程等等。其实当你一个项目做完到了维护阶段时,就会发现存储过程给我...

SQL Server 2005 不能通过ip地址访问,服务实例名可以访问

问题:可以通过服务器的实例名访问SQL服务器,但不能IP地址访问.1.netstat -an查看服务端是否打开了14332.是否安装防火墙,先关掉防火墙试试3.测试telnet 127.0.0.1 1...

SQLServer数据库的锁类型总结------[Microsoft Sql Server 2005]

SQL Server锁类型总结:  1.HOLDLOCK: 在该表上保持共享锁,直到整个事务结束,而不是在语句执行完立即释放所添加的锁。  2.NOLOCK:不添加共享锁和排它锁,当这个选项生效后,可...

完全卸载Microsoft SQL Server 2005的方法总结

从网上找了很多资料,在我实施的过程中总是还差那么一点,最终结合网上大家提供的方法,我终于卸载完全了,现根据网上的资料总结如下: SQL Server 2005卸载时特别麻烦,如果只是按照平常的方...

Microsoft SQL Server 2005简体中文开发版下载

Microsoft SQL Server 2005 开发版使开发人员能够在32位和X64平台的基础上建立和测试任意一种基于SQL Server 的应用系统。它包括企业版所有功能,但只被授权用于开发和测...

Microsoft SQL Server 2005 中相关问题的解决办法

Microsoft SQL Server 2005 中无法创建“数据库关系图”的解决办法  Microsoft SQL Server 2005 数据库中,经常会出现无法创建“数据库关系图”的错误...

安装MICROSOFT sql server 2005之一波三折

一波三折,书法术语。用笔时平捺称“波”,一波三折,指凡写捺笔要三次转换笔锋。经过三折之后,笔画才波发矫健。寓意事情进行中意外的变化很多。英译为:full of twists and turns or ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)