EducationSoftwareStrategy.com
StrategyCommunity

Knowledge Base

Product

Community

Knowledge Base

TopicsBrowse ArticlesDeveloper Zone

Product

Download SoftwareProduct DocumentationSecurity Hub

Education

Tutorial VideosSolution GalleryEducation courses

Community

GuidelinesGrandmastersEvents
x_social-icon_white.svglinkedin_social-icon_white.svg
Strategy logoCommunity

© Strategy Inc. All Rights Reserved.

LegalTerms of UsePrivacy Policy
  1. Home
  2. Topics

KB7332: How to Retrieve Column Data Type Information For an Attribute in MicroStrategy Intelligence Server SDK 9.x


Community Admin

• Strategy


Form expressions for an attribute can be retrieved from related table information using the MicroStrategy Intelligence Server SDK 9.x, as shown in KB6100-007-0003. From the same table information, column's data type can also be obtained.

Form expressions for an attribute can be retrieved from related table information using the Strategy Intelligence Server SDK 9.x, as shown in KB6100-007-0003. From the same table information, column's data type can also be obtained.
Take an example of attribute 'Date' in Strategy VMall sample project.

ka04W000001MKxcQAG_0EM440000002H1D.gif

 
There is only one form 'ID' associated with this attribute, but with two expressions 'Date_Id' and 'Order_Date'. Each expression is linked to three database tables.
 
The following sample code shows how to retrieve column data type information by using IDSSColumn::DataType API call.
 


'obtain the attribute object 
    Dim dateAttr As IDSSAttribute 
    Set dateAttr = mobjObjSource.Schema.Attributes.Item(10) 
    'index 10 is for "date" attribute. In real programming you may obtain this attribute by searching 
    
    'search for all tables that this attribute linked to 
    Dim oSearch As IDSSSearch 
    Set oSearch = mobjObjSource.NewObject(DssTypeSearch) 
    
    oSearch.Clear 
    oSearch.Types.Add DssTypeTable 
    oSearch.Uses.Add dateAttr.Info 
    
    Dim oResult As IDSSFolder 
    Set oResult = mobjObjSource.ExecuteSearch(oSearch) 
    
    Dim aTable As IDSSTable Dim i, j 
        'loop into the all these tables and find the information related to this attribute 
        
        For i = 1 To oResult.Count 
            Set aTable = oResult.Item(i).Special 
        
            For j = 1 To aTable.AttributeInfos.Count 
                If aTable.AttributeInfos.Item(j).Attribute.Info.Name = "Date" Then 
                    MsgBox aTable.AttributeInfos.Item(j).LocalDefn.BaseForms.Item(0).Expression.Text 
                    MsgBox aTable.AttributeInfos.Item(j).LocalDefn.BaseForms.Item(0).Column.DataType.Type 
                End If 
            Next 
        Next

 

 
The example provided in this document is provided “as-is” and user has read the following customization warning:
ADDITIONAL INFORMATION:
The Strategy SDK allows you to customize several Strategy products and extend and integrate the Strategy business intelligence functionality into other applications. However, before changing the way Strategy products look or behave, it is helpful to understand how the application is built. For more information regarding the Strategy products or the process of customizing Strategy products, please refer to Strategy Developer Zone (https://developer.microstrategy.com).
To access the Strategy Developer Zone, you must have access to the Strategy Knowledge Base, you must have purchased the Strategy SDK, and you must be current on your Strategy maintenance agreement. If you are a US-based business and believe that you satisfy all three of these conditions but you do not have access to the Strategy Developer Zone, please contact Strategy Technical Support at support@microstrategy.com or at (703) 848-8700. If you are an international business, please contact Strategy Technical Support at the appropriate email address or phone number found at https://www.microstrategy.com/us/services/support/contact.
CUSTOMIZATION WARNING:
This customization is provided as a convenience to Strategy users and is only directly applicable to the version stated. While this code may apply to other releases directly, Strategy Technical Support makes no guarantees that the code provided will apply to any future or previous builds. In the event of a code change in future builds, Strategy Technical Support makes no guarantee that an updated version of this particular customization will be provided. In the event of a code change in future builds, Strategy may not be able to provide additional code on this matter even though this customization is provided at this time for this specific build. For enhancements to this customization or to incorporate similar functionality into other versions, contact your Account Executive to inquire about Strategy Consulting assistance.
 


Comment

0 comments

Details

Knowledge Article

Published:

March 31, 2017

Last Updated:

March 31, 2017