Class SqlMemberSource
- java.lang.Object
-
- mondrian.rolap.SqlMemberSource
-
- All Implemented Interfaces:
MemberReader,MemberSource,TupleReader.MemberBuilder
- Direct Known Subclasses:
RolapCubeHierarchy.RolapCubeSqlMemberSource
class SqlMemberSource extends Object implements MemberReader, TupleReader.MemberBuilder
ASqlMemberSourcereads members from a SQL database.It's a good idea to put a
CacheMemberReaderon top of this.- Since:
- 21 December, 2001
- Author:
- jhyde
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classSqlMemberSource.NullValuePoolFactoryDefaultSqlMemberSource.ValuePoolFactoryimplementation, used ifMondrianProperties.SqlMemberSourceValuePoolFactoryClassis not set.static interfaceSqlMemberSource.ValuePoolFactoryInterface definition for the pluggable factory used to decide which implementation ofMapto use to pool reusable values.static classSqlMemberSource.ValuePoolFactoryFactoryCreates the ValuePoolFactory which is in turn used to create property-value maps for member properties.
-
Constructor Summary
Constructors Constructor Description SqlMemberSource(RolapHierarchy hierarchy)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description RolapMemberallMember()Returns the 'all' member of the hierarchy.intcompare(RolapMember m1, RolapMember m2, boolean siblingsAreEqual)Compares two members according to their order in a prefix ordered traversal.RolapMemberdesubstitute(RolapMember member)Returns the member which was substituted.RolapMembergetDefaultMember()RolapHierarchygetHierarchy()Returns the hierarchy that this source is reading for.RolapMembergetLeadMember(RolapMember member, int n)Returns the membernaftermemberin the same level (or before, ifnis negative).intgetLevelMemberCount(RolapLevel level)Returns the number of members in this level.TupleReader.MemberBuildergetMemberBuilder()RolapMembergetMemberByKey(RolapLevel level, List<Comparable> keyValues)Looks up a member by its key value.MemberCachegetMemberCache()Returns theMemberCacheto look up members before creating them.ObjectgetMemberCacheLock()Returns the object which acts as the member cache synchronization lock.voidgetMemberChildren(List<RolapMember> parentMembers, List<RolapMember> children)Returns all members which are a child of one of the members inparentMembers, sorted by ordinal.Map<? extends Member,Access>getMemberChildren(List<RolapMember> parentMembers, List<RolapMember> children, MemberChildrenConstraint mcc)Populates a list of the children of a given set of Members, optionally applying a constraint.voidgetMemberChildren(RolapMember parentMember, List<RolapMember> children)Writes all childrenparentMembertochildren.Map<? extends Member,Access>getMemberChildren(RolapMember parentMember, List<RolapMember> children, MemberChildrenConstraint constraint)Populates a list of the children of a Member, optionally applying a constraint.intgetMemberCount()Returns an estimate of number of members in this hierarchy.RolapMembergetMemberParent(RolapMember member)voidgetMemberRange(RolapLevel level, RolapMember startMember, RolapMember endMember, List<RolapMember> memberList)Writes all members betweenstartMemberandendMemberintolist.List<RolapMember>getMembers()Returns all members of this hierarchy, sorted by ordinal.List<RolapMember>getMembersInLevel(RolapLevel level)Returns all of the members inlevelwhose ordinal lies betweenstartOrdinalandendOrdinal.List<RolapMember>getMembersInLevel(RolapLevel level, TupleConstraint constraint)Returns the members in the given Level, optionally applying a constraint.List<RolapMember>getRootMembers()Returns all members of this hierarchy which do not have a parent, sorted by ordinal.static booleanisLevelCollapsed(AggStar aggStar, RolapCubeLevel level)Determine if the given aggregate table has the dimension level specified within in (AggStar.FactTable) it, aka collapsed, or associated with foreign keys (AggStar.DimTable)static booleanlevelContainsMultipleColumns(RolapLevel level)Determine if a level contains more than a single column for its data, such as an ordinal column or property columnRolapMemberlookupMember(List<Id.Segment> uniqueNameParts, boolean failIfNotFound)Finds a member based upon its unique name.(package private) Pair<String,List<SqlStatement.Type>>makeChildMemberSql(RolapMember member, DataSource dataSource, MemberChildrenConstraint constraint)Generates the SQL statement to access the children ofmember.RolapMembermakeMember(RolapMember parentMember, RolapLevel childLevel, Object value, Object captionValue, boolean parentChild, SqlStatement stmt, Object key, int columnOffset)Creates a new member (together with its properties).booleansetCache(MemberCache cache)Sets the cache which thisMemberSourcewill write to.RolapMembersubstitute(RolapMember member)Substitutes a given member.
-
-
-
Constructor Detail
-
SqlMemberSource
SqlMemberSource(RolapHierarchy hierarchy)
-
-
Method Detail
-
getHierarchy
public RolapHierarchy getHierarchy()
Description copied from interface:MemberSourceReturns the hierarchy that this source is reading for.- Specified by:
getHierarchyin interfaceMemberSource
-
setCache
public boolean setCache(MemberCache cache)
Description copied from interface:MemberSourceSets the cache which thisMemberSourcewill write to.Cache-writeback is optional (for example,
SqlMemberSourcesupports it, andArrayMemberSourcedoes not), and the return value from this method indicates whether this object supports it.If this method returns
true, theMemberSource.getMembers(),MemberSource.getRootMembers()andMemberSource.getMemberChildren(mondrian.rolap.RolapMember, java.util.List<mondrian.rolap.RolapMember>)methods must write to the cache, in addition to returning members as a return value.- Specified by:
setCachein interfaceMemberSource- Parameters:
cache- TheMemberCachewhich the caller would like thisMemberSourceto write to.- Returns:
- Whether this
MemberSourcesupports cache-writeback.
-
getMemberCount
public int getMemberCount()
Description copied from interface:MemberSourceReturns an estimate of number of members in this hierarchy.- Specified by:
getMemberCountin interfaceMemberSource
-
substitute
public RolapMember substitute(RolapMember member)
Description copied from interface:MemberReaderSubstitutes a given member. If member is null, returns null.This method is called whenever a member is returned from the wrapped member reader and is to be returned to the caller. You could say that it translates 'to caller space'.
- Specified by:
substitutein interfaceMemberReader- Parameters:
member- Member- Returns:
- Substitute member
-
desubstitute
public RolapMember desubstitute(RolapMember member)
Description copied from interface:MemberReaderReturns the member which was substituted. If member is null, returns null.This method is called whenever the caller passes a member into a method and needs to be passed to a method on the wrapped member reader. You could say that it translates 'from caller space'.
- Specified by:
desubstitutein interfaceMemberReader- Parameters:
member- Member- Returns:
- Internal member
-
getMemberByKey
public RolapMember getMemberByKey(RolapLevel level, List<Comparable> keyValues)
Description copied from interface:MemberReaderLooks up a member by its key value.- Specified by:
getMemberByKeyin interfaceMemberReader- Parameters:
level- LevelkeyValues- Key values- Returns:
- Member, or null
-
lookupMember
public RolapMember lookupMember(List<Id.Segment> uniqueNameParts, boolean failIfNotFound)
Description copied from interface:MemberSourceFinds a member based upon its unique name.- Specified by:
lookupMemberin interfaceMemberSource
-
getLevelMemberCount
public int getLevelMemberCount(RolapLevel level)
Description copied from interface:MemberReaderReturns the number of members in this level.- Specified by:
getLevelMemberCountin interfaceMemberReader- Parameters:
level- Level- Returns:
- number of members in level
-
getMembers
public List<RolapMember> getMembers()
Description copied from interface:MemberSourceReturns all members of this hierarchy, sorted by ordinal.If this object
supports cache-writeaback, also writes these members to the cache.- Specified by:
getMembersin interfaceMemberSource
-
getMembersInLevel
public List<RolapMember> getMembersInLevel(RolapLevel level)
Description copied from interface:MemberReaderReturns all of the members inlevelwhose ordinal lies betweenstartOrdinalandendOrdinal.If this object
supports cache-writeback, also writes these members to the cache.- Specified by:
getMembersInLevelin interfaceMemberReader- Returns:
ListofRolapMember
-
getMembersInLevel
public List<RolapMember> getMembersInLevel(RolapLevel level, TupleConstraint constraint)
Description copied from interface:MemberReaderReturns the members in the given Level, optionally applying a constraint.- Specified by:
getMembersInLevelin interfaceMemberReader- Parameters:
level- Levelconstraint- Constraint- Returns:
- list of members
-
getMemberCache
public MemberCache getMemberCache()
Description copied from interface:TupleReader.MemberBuilderReturns theMemberCacheto look up members before creating them.- Specified by:
getMemberCachein interfaceTupleReader.MemberBuilder- Returns:
- member cache
-
getMemberCacheLock
public Object getMemberCacheLock()
Description copied from interface:TupleReader.MemberBuilderReturns the object which acts as the member cache synchronization lock.- Specified by:
getMemberCacheLockin interfaceTupleReader.MemberBuilder- Returns:
- Object to lock
-
getRootMembers
public List<RolapMember> getRootMembers()
Description copied from interface:MemberSourceReturns all members of this hierarchy which do not have a parent, sorted by ordinal.If this object
supports cache-writeback, also writes these members to the cache.- Specified by:
getRootMembersin interfaceMemberSource- Returns:
ListofRolapMembers
-
makeChildMemberSql
Pair<String,List<SqlStatement.Type>> makeChildMemberSql(RolapMember member, DataSource dataSource, MemberChildrenConstraint constraint)
Generates the SQL statement to access the children ofmember. For example,
retrieves the children of the memberSELECT "city" FROM "customer" WHERE "country" = 'USA' AND "state_province" = 'BC' GROUP BY "city"
[Canada].[BC].Note that this method is never called in the context of virtual cubes, it is only called on regular cubes.
See also
SqlTupleReader.makeLevelMembersSql(javax.sql.DataSource).
-
levelContainsMultipleColumns
public static boolean levelContainsMultipleColumns(RolapLevel level)
Determine if a level contains more than a single column for its data, such as an ordinal column or property column- Parameters:
level- the level to check- Returns:
- true if multiple relational columns are involved in this level
-
isLevelCollapsed
public static boolean isLevelCollapsed(AggStar aggStar, RolapCubeLevel level)
Determine if the given aggregate table has the dimension level specified within in (AggStar.FactTable) it, aka collapsed, or associated with foreign keys (AggStar.DimTable)- Parameters:
aggStar- aggregate star if existslevel- level- Returns:
- true if agg table has level or not
-
getMemberChildren
public void getMemberChildren(List<RolapMember> parentMembers, List<RolapMember> children)
Description copied from interface:MemberSourceReturns all members which are a child of one of the members inparentMembers, sorted by ordinal.If this object
supports cache-writeaback, also writes these members to the cache.- Specified by:
getMemberChildrenin interfaceMemberSource
-
getMemberChildren
public Map<? extends Member,Access> getMemberChildren(List<RolapMember> parentMembers, List<RolapMember> children, MemberChildrenConstraint mcc)
Description copied from interface:MemberReaderPopulates a list of the children of a given set of Members, optionally applying a constraint.- Specified by:
getMemberChildrenin interfaceMemberReader- Parameters:
parentMembers- List of members whose children to findchildren- List to populate with membersmcc- Constraint- Returns:
- After populating the list passed as an argument,
this method returns a map of the members it just populated
along with the Access information applicable. If no access
control applies to the member, the map will contain
nullvalues.
-
getMemberChildren
public void getMemberChildren(RolapMember parentMember, List<RolapMember> children)
Description copied from interface:MemberSourceWrites all childrenparentMembertochildren.If this object
supports cache-writeback, also writes these members to the cache.- Specified by:
getMemberChildrenin interfaceMemberSource
-
getMemberChildren
public Map<? extends Member,Access> getMemberChildren(RolapMember parentMember, List<RolapMember> children, MemberChildrenConstraint constraint)
Description copied from interface:MemberReaderPopulates a list of the children of a Member, optionally applying a constraint.- Specified by:
getMemberChildrenin interfaceMemberReader- Parameters:
parentMember- Members whose children to findchildren- List to populate with membersconstraint- Constraint- Returns:
- After populating the list passed as an argument,
this method returns a map of the members it just populated
along with the Access information applicable. If no access
control applies to the member, the map will contain
nullvalues.
-
makeMember
public RolapMember makeMember(RolapMember parentMember, RolapLevel childLevel, Object value, Object captionValue, boolean parentChild, SqlStatement stmt, Object key, int columnOffset) throws SQLException
Description copied from interface:TupleReader.MemberBuilderCreates a new member (together with its properties).- Specified by:
makeMemberin interfaceTupleReader.MemberBuilder- Parameters:
parentMember- Parent memberchildLevel- Child levelvalue- Member valuecaptionValue- CaptionparentChild- Whether a parent-child hierarchystmt- SQL statementkey- Member keycolumnOffset- Column ordinal (0-based)- Returns:
- new member
- Throws:
SQLException- on error
-
allMember
public RolapMember allMember()
Description copied from interface:TupleReader.MemberBuilderReturns the 'all' member of the hierarchy.- Specified by:
allMemberin interfaceTupleReader.MemberBuilder- Returns:
- The 'all' member
-
getLeadMember
public RolapMember getLeadMember(RolapMember member, int n)
Description copied from interface:MemberReaderReturns the membernaftermemberin the same level (or before, ifnis negative). ReturnsHierarchy.getNullMember()if we run off the beginning or end of the level.- Specified by:
getLeadMemberin interfaceMemberReader
-
getMemberRange
public void getMemberRange(RolapLevel level, RolapMember startMember, RolapMember endMember, List<RolapMember> memberList)
Description copied from interface:MemberReaderWrites all members betweenstartMemberandendMemberintolist.- Specified by:
getMemberRangein interfaceMemberReader
-
compare
public int compare(RolapMember m1, RolapMember m2, boolean siblingsAreEqual)
Description copied from interface:MemberReaderCompares two members according to their order in a prefix ordered traversal. IfsiblingsAreEqual, then two members with the same parent will compare equal.- Specified by:
comparein interfaceMemberReader- Returns:
- less than zero if m1 occurs before m2,
greater than zero if m1 occurs after m2,
zero if m1 is equal to m2, or if
siblingsAreEqualand m1 and m2 have the same parent
-
getMemberBuilder
public TupleReader.MemberBuilder getMemberBuilder()
- Specified by:
getMemberBuilderin interfaceMemberReader
-
getDefaultMember
public RolapMember getDefaultMember()
- Specified by:
getDefaultMemberin interfaceMemberReader
-
getMemberParent
public RolapMember getMemberParent(RolapMember member)
- Specified by:
getMemberParentin interfaceMemberReader
-
-