壹佰网|ERP100 - 企业信息化知识门户

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 494|回复: 0

SSAS命名计算的SQL语法需遵循"源"数据提供者的要求

[复制链接]
发表于 2012/3/15 23:37:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。如果您注册时有任何问题请联系客服QQ: 83569622  。

您需要 登录 才可以下载或查看,没有帐号?注册

x
在SSAS数据源视图中,命名计算是一个表示为计算列的 SQL 表达式。使用命名计算,可以扩展数据源视图中现有表或视图的关系架构,而无需修改基础数据源中的表或视图。

有些初学者看到命名计算一般是在SSAS的DEV Studio中定义的,很容易误解命名计算的SQL语法应符合SSAS(也就是sql server)支持的范围。而实际上并非如此,这一点如果了解数据源视图的性质及作用后即可熟悉。

同时,也可以从SSAS文档中隐晦的获知:

定义完命名计算之后,便会将命名计算中的表达式发送到数据源的提供程序 ,然后将表达式作为以下 SQL 语句进行验证,在该语句中,<Expression> 包含定义命名计算的表达式。

SELECT
   <Table Name in Data Source>.*,
   <Expression
> AS <Column Name>
FROM
   <Table Name in Data Source> AS <Table Name in Data Source View>列的数据类型由表达式返回的标量值的数据类型确定。 如果提供程序没有在表达式中找到任何错误 ,则将该列添加到表内。

------引自《SSAS联机文档》


请留意上述内容中红色字体的内容,可发现命名计算的语法需要符合源数据提供者的,因为命名计算是被提交到源数据提供者处理并执行的。

比如:如果源数据提供者为Access,则定义一个包含Case语句的命名计算是错误的,如果要完成对等的逻辑,必须将Case语句转换为Access支持的判断语句,如IIF等。

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|手机版|壹佰网 ERP100 ( 京ICP备19053597号-2 )

Copyright © 2005-2012 北京海之大网络技术有限责任公司 服务器托管由互联互通
手机:13911575376
网站技术点击发送消息给对方83569622   广告&合作 点击发送消息给对方27675401   点击发送消息给对方634043306   咨询及人才点击发送消息给对方138011526

GMT+8, 2025/11/30 11:57 , Processed in 0.011860 second(s), 14 queries , File On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表