码迷,mamicode.com
首页 > 其他好文 > 详细

维度属性的KeyColumns如果是Integer类型,那么维度表中该列的值不能有为null的

时间:2017-03-13 20:22:53      阅读:356      评论:0      收藏:0      [点我收藏+]

标签:char   wchar   null   int   ges   分享   open   key   技术   

如果维度属性的 KeyColumns的DataType设置为了Integer类型,那么要注意该维度属性列在数据库中不能有为null的值。

 

例如下图中我们有维度DIM_Vehcile,其中有个维度属性叫Vehicle Year,该属性的 KeyColumns的DataType设置为了Integer类型,如果现在数据库中DIM_Vehcile表的字段VehicleYear有为null的值,那么处理维度DIM_Vehcile时,会报Duplicate Key Error

技术分享

 

这是因为如果维度属性Vehicle Year的KeyColumns设置为了Integer,那么SSAS会将数据库DIM_Vehcile表VehicleYear字段为null的值转换为0,来作为维度属性Vehicle Year的KeyColumns值。因为SSAS认为如果维度属性KeyColumns的DataType设置为了Integer,那么该维度属性不应该会出现null值,所以SSAS就擅自将null自动转换为了0来作为KeyColumns值,但是维度属性的Value又是可以null的(维度属性的Value会将null转换为""空字符),所以导致维度属性Vehicle Year的Key值0对应了两个不同的Value值:""(数据库中VehicleYear字段为null的值)和0(数据库中VehicleYear字段正真为0的值),处理维度时发生错误。

 

要解决这个问题就必须要将维度属性Vehicle Year的KeyColumns的DataType从Integer类型改为WChar字符串类型,这样SSAS就不会擅自将null自动转换为0来作为维度属性Vehicle Year的KeyColumns值了,而是将null也转换为空字符串""作为KeyColumns值,这样维度属性Vehicle Year的Key值0只会对应一个Value值0,而Key值""也只会对应一个Value值""。如下图设置所示:

技术分享

 

维度属性的KeyColumns如果是Integer类型,那么维度表中该列的值不能有为null的

标签:char   wchar   null   int   ges   分享   open   key   技术   

原文地址:http://www.cnblogs.com/OpenCoder/p/6544614.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!