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

如果维度属性的 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值""。如下图设置所示:

时间: 2024-08-04 19:38:40

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

java5核心基础之泛型(3)-泛型作用于编译阶段-怎样将String对象传入Integer类型的泛型对象中?

泛型作用于编译阶段: 泛型是作用于编译阶段,在编译阶段控制类型,以确保在编写代码的时候仅仅能传入指定类型数据到泛型集合对象中去. 怎样验证呢,贴代码例如以下: package highBasic.generic; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.util.ArrayList; public class StringAddToGeneri

java5核心基础之泛型(3)-泛型作用于编译阶段-如何将String对象传入Integer类型的泛型对象中?

泛型作用于编译阶段: 泛型是作用于编译阶段,在编译阶段控制类型,以确保在编写代码的时候只能传入指定类型数据到泛型集合对象中去.如何验证呢,贴代码如下: package highBasic.generic; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.util.ArrayList; public class StringAddToGenericInt

维度属性的KeyColumns,NameColumn和ValueColumn

维度的每一个属性都有KeyColumns,NameColumn和ValueColumn 1,如何理解KeyColumns,NameColumn和ValueColumn?对一行记录有不同的标识列,但标识的是同一行记录. 对于int类型,占用存储空间小,容易聚合,适合做primary key,但是不易阅读: char类型的数据,容易阅读,适合作为Name Column: 对于一个有具体类型的数据,其value必须能够做一些运算,例如Date类型,能够做Year(),dateadd()等运算,这些可以

SQL 表中增加列,指定类型,是否为空,设置默认值

SQL语法: ALTER TABLE 表名ADD 字段 类型 not null  default(默认值) 例如:在A表中增加字段Prcie(价格) 类型为money  不能为空 默认值为0.0 SQL如下: ALTER TABLE A ADD Price money not null default(0.0)

为SQL Server表中的列添加/修改/删除注释属性(sp_addextendedproperty、sp_updateextendedproperty、sp_dropextendedproperty)

本篇基本完全参考:sql--sp_addextendedproperty和sp_updateextendedproperty (Transact-SQL) 三个存储过程用法一样,以sp_addextendedproperty为例: sp_addextendedproperty [ @name = ]{ 'property_name' } [ , [ @value = ]{ 'value' } [, [ @level0type = ]{ 'level0_object_type' } , [ @le

实践001:char 类型字段在表中的长度

Rainy on 20170215 1.同事在 写RFC的时候遇到报错:"YTST_001" 必须为扁平结构.不能将内部表.字符# 原因是自建结构中字段定义为了string 类型.关于 扁平结构的概念有些疑惑??? 2.CHAR类型长度限制,主键 <= 220  ,当主键>120 位长度,激活时系统会警告[:关键字长度 > 120 (限制功能)][ 最好是<=120 ,如果大于此长度则并不适合做主键 ]普通字段 <= 1333 [建议可定义为 1024,开

[MySQL]--MySQL表中某个列插入数据总被截断,报编码方式的语法错误,实际是column的not null属性和更改编码语法导致的冲突。

MySQL的编码方式中,常用的有gb2312<gbk<utf8. MySQL的编码方式的查看,常用三个参数:character_set_client, character_set_connection ,character_set_result. 查询goods表的列的编码情况: show full columns from goods; 在三个参数一样的情况下,发现goods表中的goods_name的值被截断了,单独插入一行数据的时候,报字符编码错误. 用alter table chang

MySql常见数据类型,SQL执行顺序,条件语句,转储,查看表中字段属性

数据类型: 1 数字: Tinyint:小数据 用于保存一些范围的整数数值范围 有符号: -128-127 无符号: 0-255 int 整数 数据类型用于保存一些范围的整数数值范围 有符号: -2147483648--2147483647 无符号: 0-4294967295 Bigint 大整数 数据类型用于保存一些范围的整数数值范围: 有符号: -9223372036854775808--9223372036854775807 无符号: 0-18446744073709551615 floa

C#读取注册表中二进制类型的值(REG_BINARY)

如需要读取注册表中某个键的值, 例如读取DriverDesc对应的值,一般情况下为String类型,读取代码如下: RegistryKey driverKey = Registry.LocalMachine.OpenSubKey(@"System\CurrentControlSet\Control\Class\{4D36E968-E325-11CE-BFC1-08002BE10318}\0000"); string result = (String)driverKey.GetValue