SQL2005CLR函数扩展-深入环比计算的详解

  次阅读 来源:互联网(转载协议) 2016-03-01 10:10 我要评论(0)

环比就是本月和上月的差值所占上月值的比例。在复杂的olap计算中我们经常会用到同比环比等概念,要求的上个维度的某个字段的实现语句非常简练,比如ssas的mdx语句类似[维度].CurrentMember.Prevmember就可以了

此类问题还可以延伸到类似进销存的批次计算中,这也要关注其他历史记录来决定当前某条记录的状态。

sql语句无法简单实现mdx语句的类似功能,必须得用交叉表关联来对比。这里我们用CLR函数来实现mdx语句的类似语法。在select的时候把得到过的做个缓存就可以了。效率应该可以提高不少。

clr的代码如下,编译为TestFun.dll,复制到sql服务器的文件目录下。

--------------------------------------------------------------------------------

复制代码 代码如下:

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

public partial class UserDefinedFunctions

{

// 保存当前组当前值

private static System.Collections.Generic.Dictionary <string ,SqlString > _listValue = new System.Collections.Generic.Dictionary<string , SqlString >();

// 保存当前组

private staticSystem.Collections.Generic.Dictionary <string , string >_listGroup= new System.Collections.Generic.Dictionary <string ,string >();

/// <summary>

/// 获取当前组上条记录数值

/// </summary>

/// <param name="key"> 并发键 </param>

/// <param name="currentGroup"> 当前组 </param>

/// <param name="currentValue"> 当前组当前值 </param>

/// <returns></returns>

[Microsoft.SqlServer.Server.SqlFunction ]

public static SqlString GetPrevMemberValue(SqlString key,SqlString currentGroup,SqlString currentValue)

{

if (key.IsNull || currentGroup.IsNull) return SqlString .Null;

try

{

SqlString prevMemberValue = _listValue[key.Value];

// 组变更

if (_listGroup[key.Value] != currentGroup.Value)

{

prevMemberValue = SqlString .Null;

_listGroup[key.Value] = currentGroup.Value;

}

// 值变更

_listValue[key.Value] = currentValue;

return prevMemberValue;

}

catch

{

return SqlString .Null;

}

}

/// <summary>

/// 初始化并发键

/// </summary>

/// <param name="key"></param>

/// <returns></returns>

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 全球陷入"区块链狂热"潮,大规模应用还需等待

    全球陷入"区块链狂热"潮,大规模应用还需等待

  • 汤晓鸥:人工智能的中国式文艺复兴

    汤晓鸥:人工智能的中国式文艺复兴

  • 区块链最近太火,但A股多家公司明确表态不考虑涉足

    区块链最近太火,但A股多家公司明确表态不考虑涉足

  • 马云的新零售?张近东的智慧零售?抑或是刘强东的第四次零售革命?

    马云的新零售?张近东的智慧零售?抑或是刘强东的第四次零售革命?

网友点评网友点评
阅读推荐阅读推荐

算法 任何一个入门的软件开发人员都会听到这句话:算法是软件的灵魂!近年来大火的机器学习即是在算法在人工智能上的集中体现。今日头条通...

据《日本经济新闻》报道,日本东京大学教授稻叶雅幸等人开发出再现日本人骨骼肌肉构造的机器人。机器人各部位的肌肉和骨骼长度与日本人的平...

以奥黛丽-赫本为原型打造的人形机器人索菲娅首次拜访了印度。索菲娅是世界上首位获得公民身份的机器人,她在12月30日出现在了印度理工学院...

在查获现场,代售点电脑旁的一台机器人通过敲击电脑键盘抢票。 广州日报惠州讯 (全媒体记者秦仲阳 通讯员张中铃摄影报道)2018年春运售票已...