|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object mondrian.rolap.SmartMemberReader
public class SmartMemberReader
SmartMemberReader
implements MemberReader
by keeping a
cache of members and their children. If a member is 'in cache', there is a
list of its children. It also caches the members of levels.
Synchronization: the MemberReader source
must be called
from synchronized(this) context - it does not synchronize itself (probably
it should).
Constraints: Member.Children and Level.Members may be constrained by a SqlConstraint object. In this case a subset of all members is returned. These subsets are cached too and the SqlConstraint is part of the cache key. This is used in NON EMPTY context.
Uniqueness. We need to ensure that there is never more than one RolapMember
object representing the same member.
Nested Class Summary | |
---|---|
(package private) class |
SmartMemberReader.SiblingIterator
SiblingIterator helps traverse a hierarchy of members, by
remembering the position at each level. |
Field Summary | |
---|---|
protected MemberCacheHelper |
cacheHelper
|
protected List<RolapMember> |
rootMembers
|
protected MemberReader |
source
access to source must be synchronized(this) |
Constructor Summary | |
---|---|
SmartMemberReader(MemberReader source)
|
Method Summary | |
---|---|
protected void |
checkCacheStatus()
|
int |
compare(RolapMember m1,
RolapMember m2,
boolean siblingsAreEqual)
Compares two members according to their order in a prefix ordered traversal. |
RolapMember |
desubstitute(RolapMember member)
Returns the member which was substituted. |
RolapMember |
getDefaultMember()
|
RolapHierarchy |
getHierarchy()
Returns the hierarchy that this source is reading for. |
RolapMember |
getLeadMember(RolapMember member,
int n)
Returns the member n after member in the same
level (or before, if n is negative). |
int |
getLevelMemberCount(RolapLevel level)
Returns the number of members in this level. |
TupleReader.MemberBuilder |
getMemberBuilder()
|
MemberCache |
getMemberCache()
|
void |
getMemberChildren(List<RolapMember> parentMembers,
List<RolapMember> children)
Returns all members which are a child of one of the members in parentMembers , sorted by ordinal. |
void |
getMemberChildren(List<RolapMember> parentMembers,
List<RolapMember> children,
MemberChildrenConstraint constraint)
Populates a list of the children of a given set of Members, optionally applying a constraint. |
void |
getMemberChildren(RolapMember parentMember,
List<RolapMember> children)
Writes all children parentMember to children . |
void |
getMemberChildren(RolapMember parentMember,
List<RolapMember> children,
MemberChildrenConstraint constraint)
Populates a list of the children of a Member, optionally applying a constraint. |
int |
getMemberCount()
Returns an estimate of number of members in this hierarchy. |
RolapMember |
getMemberParent(RolapMember member)
|
void |
getMemberRange(RolapLevel level,
RolapMember startMember,
RolapMember endMember,
List<RolapMember> list)
Writes all members between startMember and
endMember into list . |
List<RolapMember> |
getMembers()
Returns all members of this hierarchy, sorted by ordinal. |
List<RolapMember> |
getMembersInLevel(RolapLevel level,
int startOrdinal,
int endOrdinal)
Returns all of the members in level whose ordinal lies
between startOrdinal and endOrdinal . |
List<RolapMember> |
getMembersInLevel(RolapLevel level,
int startOrdinal,
int endOrdinal,
TupleConstraint constraint)
Returns the members in the given Level, optionally between a range of ordinals and applying a constraint. |
List<RolapMember> |
getRootMembers()
Returns all members of this hierarchy which do not have a parent, sorted by ordinal. |
boolean |
isSorted(List<RolapMember> members)
Returns true if every element of members is not null and is
strictly less than the following element; false otherwise. |
RolapMember |
lookupMember(List<Id.Segment> uniqueNameParts,
boolean failIfNotFound)
Finds a member based upon its unique name. |
protected void |
readMemberChildren(List<RolapMember> members,
List<RolapMember> result,
MemberChildrenConstraint constraint)
Reads the children of member into cache, and also into
result . |
boolean |
setCache(MemberCache cache)
Sets the cache which this MemberSource will write to. |
RolapMember |
substitute(RolapMember member)
Substitutes a given member. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected final MemberReader source
source
must be synchronized(this)
protected final MemberCacheHelper cacheHelper
protected List<RolapMember> rootMembers
Constructor Detail |
---|
SmartMemberReader(MemberReader source)
Method Detail |
---|
public RolapHierarchy getHierarchy()
MemberSource
getHierarchy
in interface MemberSource
public MemberCache getMemberCache()
public boolean setCache(MemberCache cache)
MemberSource
MemberSource
will write to.
Cache-writeback is optional (for example, SqlMemberSource
supports it, and ArrayMemberSource
does not), and the return
value from this method indicates whether this object supports it.
If this method returns true
, the MemberSource.getMembers()
,
MemberSource.getRootMembers()
and MemberSource.getMemberChildren(mondrian.rolap.RolapMember, java.util.List
methods must
write to the cache, in addition to returning members as a return value.
setCache
in interface MemberSource
cache
- The MemberCache
which the caller would like
this MemberSource
to write to.
MemberSource
supports cache-writeback.public RolapMember substitute(RolapMember member)
MemberReader
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'.
substitute
in interface MemberReader
member
- Member
public RolapMember desubstitute(RolapMember member)
MemberReader
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'.
desubstitute
in interface MemberReader
member
- Member
public List<RolapMember> getMembers()
MemberSource
If this object supports cache-writeaback
, also
writes these members to the cache.
getMembers
in interface MemberSource
public List<RolapMember> getRootMembers()
MemberSource
If this object supports cache-writeback
, also
writes these members to the cache.
getRootMembers
in interface MemberSource
List
of RolapMember
spublic List<RolapMember> getMembersInLevel(RolapLevel level, int startOrdinal, int endOrdinal)
MemberReader
level
whose ordinal lies
between startOrdinal
and endOrdinal
.
If this object
supports cache-writeback
, also
writes these members to the cache.
getMembersInLevel
in interface MemberReader
List
of RolapMember
protected void checkCacheStatus()
public List<RolapMember> getMembersInLevel(RolapLevel level, int startOrdinal, int endOrdinal, TupleConstraint constraint)
MemberReader
getMembersInLevel
in interface MemberReader
level
- LevelstartOrdinal
- Ordinal of first member to retrieveendOrdinal
- Ordinal of last member to upper boundconstraint
- Constraint
public int getLevelMemberCount(RolapLevel level)
MemberReader
getLevelMemberCount
in interface MemberReader
level
- Level
public void getMemberChildren(RolapMember parentMember, List<RolapMember> children)
MemberSource
parentMember
to children
.
If this object supports cache-writeback
, also
writes these members to the cache.
getMemberChildren
in interface MemberSource
public void getMemberChildren(RolapMember parentMember, List<RolapMember> children, MemberChildrenConstraint constraint)
MemberReader
getMemberChildren
in interface MemberReader
parentMember
- Members whose children to findchildren
- List to populate with membersconstraint
- Constraintpublic void getMemberChildren(List<RolapMember> parentMembers, List<RolapMember> children)
MemberSource
parentMembers
, sorted by ordinal.
If this object supports cache-writeaback
, also
writes these members to the cache.
getMemberChildren
in interface MemberSource
public void getMemberChildren(List<RolapMember> parentMembers, List<RolapMember> children, MemberChildrenConstraint constraint)
MemberReader
getMemberChildren
in interface MemberReader
parentMembers
- List of members whose children to findchildren
- List to populate with membersconstraint
- Constraintpublic RolapMember lookupMember(List<Id.Segment> uniqueNameParts, boolean failIfNotFound)
MemberSource
lookupMember
in interface MemberSource
protected void readMemberChildren(List<RolapMember> members, List<RolapMember> result, MemberChildrenConstraint constraint)
member
into cache, and also into
result
.
result
- Children are written here, in ordermembers
- Members whose children to readconstraint
- restricts the returned members if possible (optional
optimization)public boolean isSorted(List<RolapMember> members)
members
is not null and is
strictly less than the following element; false otherwise.
public RolapMember getLeadMember(RolapMember member, int n)
MemberReader
n
after member
in the same
level (or before, if n
is negative).
Returns Hierarchy.getNullMember()
if we run off the beginning or
end of the level.
getLeadMember
in interface MemberReader
public void getMemberRange(RolapLevel level, RolapMember startMember, RolapMember endMember, List<RolapMember> list)
MemberReader
startMember
and
endMember
into list
.
getMemberRange
in interface MemberReader
public int getMemberCount()
MemberSource
getMemberCount
in interface MemberSource
public int compare(RolapMember m1, RolapMember m2, boolean siblingsAreEqual)
MemberReader
siblingsAreEqual
, then two members with the
same parent will compare equal.
compare
in interface MemberReader
siblingsAreEqual
and
m1 and m2 have the same parentpublic TupleReader.MemberBuilder getMemberBuilder()
getMemberBuilder
in interface MemberReader
public RolapMember getDefaultMember()
getDefaultMember
in interface MemberReader
public RolapMember getMemberParent(RolapMember member)
getMemberParent
in interface MemberReader
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |