TDecisionCube维护它提供给TDectisionSource对象的交叉制表的数据。 TCecisioncube对象加到一个窗体或数据模块,可以允许应用程序表示交叉制表的数据, TDecisionCube将来自源数据集的数据分解成每一维相当于被概括信息的数据集的一个字段的多维结构。任何数据集都可以用作TDecisioncube对象的源,但对TDecisionQuery工作将更容易。 通常,总计值为决策立主图表的源的数据集计算。然而作为代替,平均值可以被Decision Cube内部计算,内部计算的平均值有一个优势,他们可以被Decision网格一正确地数据透视、部分总计、训练,该网格显示来自Decision Cube 的数据。 TDecisioncube引进了允许交叉制表的数据存储以提供数据给TDecisionsource对象的属性和方法。Decision网格和Decision图表不直接从决策立主图表检索数据。它们使用说明来自TDecisionCube对象的维数配置的TDecisionSource对象。
属性列表 Active 指明决策立主图表是否可以提供数据 DesignState 在设计期间确定有多少数据由决策立主图表显示
方法列表 ~TDecisionCube 删除一个TDecisionCube 实例 GetDetailSQL 生成数据描述子集的SQL语句 GetSQL 生成数据描述子集的SQL语句 ShowCubeDialog 显示Decision Cube编辑器 TDecisioncube 创建一个TDecisionCube实例
属性 TDecisionCube::Active 指明决策立主图表是否可以提供数据。 __property bool Active={read=CubeGetActive,write=CubeSetActive, nodefault}; 读Active可以确定决策立主图表是否准备提供数据给决策控件。设置Active 为TRue可以引起决策立主图表去获得和分解来自DataSet属性指定数据集的数据。当Active为GAlse时,决策立生图表被子关闭,且决策源不能从决策立主图表读数据。当Active为True时,可以从决策立主图表读数据。 Acitve属性不能被设置为True ,除非由DataSet属性指定的数据集已经激活。
TDecisionCube::DesignState 在设计期间确定有多少数据由决策立主图表显示。 enum TCubeDataState {dsNodata,dsMetatea,dsDimensionData,daAlldaata}; __property TCubeDataState DesignState = {read= FDesignState, write=SetdesignState,nodefault}; 在设计期间设置DesignState可以限制当决策立主图表是激活时被提供的信息量。建立缓存可以加快时间,加强内存。限制决策立主图表所能提供的信息在决策立主图表有好多维或维数有好多值时可以改变设计时间。DesignState可以是一列值之一: 值 说明 dsNoData 决策立主图表不能在设计期间被激活 dsMstaData 决策立主图表提供维数说明,但没有维数的值的列表,也没有总计值 dsDimensionData 决策立主图表提供维数说明,和维数字段的值,但没有总计值 dsAllData 决策立主图表提供所有可以的数据;维数说明,维数据字段的值,总计值 在设计期间使用Decision Cube编辑器可以改变DesignState的Value.
方法 TDecisionCube::~TDecisionCube 删除一个TDecisionCube实例。 __fastcall virtual ~TDecisionCube(void); 不要直接调用Destroy,而应调用Free,Faee验证是否决策立主图表的内存已经被释放,然后再调用Destroy.
TDecisionCabe::GetDetailSQL 返回一个被用来在决策立主图表中生成数据的描述子集的SQL语句。 System::AnsiString__fastcall GetDetallSQL ( Mxarrays::TSmallIntArray* ValueArray,System::AnsiSring SelectList,bool bActive); 使用由GetSQL返回的SQL语句可以看使决策立主图表中的信息的子集生成的数据。由此生成的查询产生的一个包括由ValueArray参数描述的投影图的数据集。当前数据集的所有概要都被包括在由此生成的查询中。 查询并不包括任何总计值或分组,必须由决策立主图表的数据集加入 。ValueArray参数中的每一条目与决策立主图表的维数相应,第一个条目与第二个维数相对应,以此类推。若在值数组中的一个条目的值小于0,在那个维数的所有字段值被包括在新的数据集中,若在值数组中的一个条目的值等于0或大于0,它被翻译成该维数字段值的索引。ValueArray指定一个字段值时,SQL语句限制数据集为与初始数据库表的相应字段值相匹配的记录。因此,ValueArray说明带一套已训练维数的维数数组。 bActive指出是否ValueArray参数包括不激活的维数。当bActive为True时仅激活的维数被包括。若要进一步数据集以使它仅包括决策立主图表的维数的子集,使用GetDetailSQL方法。
TDecisionCube::ShowCubeDialog 显示Decision Cube编辑器。 void__fastcall ShowCubeDialog(void); 调用ShowCubeDialog可以允许用户使用Decision Cube编辑器改变数据立主图表的激活维数。 ShiwCubeDialog生成与在设计期间,通过决策立主图表组件的弹出菜单选中Decision Cube编辑器时出现的对话框一样的对话框。 Decision Cube编辑器允许用户使维数激活或不激活, 并且改变维数的名称。它也控制着在设计期间在决策控件上显示多少信息。
TDecisionCube::TDecisionCube 创建一个TDecisionCube实例。 __fastcall virtual TDecisionCube(Classes::TComponent* AOwner); 利用new间接调用TDecisionCube,可以在运行期间创建一个决策立主图表的实例。对于在设计期间放在窗体上的决策立主图表,TDecisionCube被自动调用。 TDecisionCube为决策立主图表和它的助手对象分配内存并初始化Active属性为False,DesignState属性为dsAllData。  
|