Class TableMapClient
- All Implemented Interfaces:
- com.fishlib.base.log.LogOutputAppendable,- Deflatable<TableMap>,- LivenessManager,- LivenessNode,- LivenessReferent,- DynamicNode,- TableMap,- TransformableTableMap,- Serializable
public class TableMapClient extends TableMapImpl
- See Also:
- Serialized Form
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classTableMapClient.TableMapGetGet a table from aTableMapapplying approriate ACLs before returningstatic classTableMapClient.TableMapGetKeysstatic classTableMapClient.TableMapGetMergedGet a merged table of multiple keys from aTableMapapplying approriate ACLs before returningstatic classTableMapClient.TableMapMergeNested classes/interfaces inherited from interface com.illumon.iris.db.v2.TableMapTableMap.KeyListener, TableMap.ListenerNested classes/interfaces inherited from interface com.illumon.iris.db.v2.TransformableTableMapTransformableTableMap.AsTableBuilder
- 
Field Summary
- 
Constructor SummaryConstructors Constructor Description TableMapClient(QueryProcessorConnection processorConnection, int id)
- 
Method SummaryModifier and Type Method Description <R> Rapply(com.fishlib.base.Function.Unary<R,TableMap> function)Applies a function to this tableMap.TableasTable(boolean strictKeys, boolean allowCoalesce, boolean sanityCheckJoins)Create a Table out of this TableMap's values.voiddropReference()Drop a previously-retained reference to this referent.Collection<Map.Entry<Object,Table>>entrySet()Gets the entries.TableMapflatten()Flattens all of the result tables within the tablemap.Tableget(Object key)Gets a table with a given key.intgetId()Object[]getKeySet()Gets the keys.WeakReference<? extends LivenessReferent>getWeakReference()Get aWeakReferenceto this referent.TablegetWithTransform(Object key, Function<Table,Table> transform)Gets a table with a given key, applying the specified transform before returning.voidinitializeTransientFieldsForLiveness()Package-private forSerializablesub-classes to use inreadObjectonly.Tablemerge()Merges all of the component tables into a single Table.voidonKeyAddition(Object key)protected voidonReferenceCountAtZero()Callback method that will be invoked when the reference count returns to zero.TableMappopulateKeys(Object... keys)When creating the table map, some of the keys that we would like to be there eventually may not exist.TableMappreemptiveUpdatesTable(int intervalMillis)Creates preemptive tables out of all of the result tables within the tablemap.intsize()Number of tables in the map.TableMaptransformTablesWithKey(TableDefinition returnDefinition, BiFunction<Object,Table,Table> function)Applies a transformation function on all tables in the TableMap, producing a new TableMap which will update as new keys are added.TableMaptransformTablesWithKey(BiFunction<Object,Table,Table> function)Applies a transformation function on all tables in the TableMap, producing a new TableMap which will update as new keys are added.TableMaptransformTablesWithMap(TableMap otherMap, BiFunction<Table,Table,Table> function)Applies a BiFunction function on all tables in this TableMap and otherMap that have matching keys, producing a new TableMap which will update as new keys are added.booleantryManage(LivenessReferent referent)Attempt to add the specified referent to this manager.booleantryRetainReference()If this referent is "live", behave asLivenessReferent.retainReference()and return true.Collection<Table>values()Gets the values.Methods inherited from class com.illumon.iris.db.v2.TableMapImpladdKeyListener, addListener, addParentReference, destroy, isRefreshing, notifyKeyListeners, notifyListeners, removeKeyListener, removeListener, setRefreshingMethods inherited from class com.illumon.iris.db.util.liveness.LivenessArtifactmanageWithCurrentScope, unmanage, unmanageMethods inherited from class com.illumon.util.referencecounting.ReferenceCountedappend, decrementReferenceCount, incrementReferenceCount, resetReferenceCount, toString, tryDecrementReferenceCount, tryIncrementReferenceCountMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface com.illumon.iris.db.util.liveness.LivenessManagermanage, tryManageMethods inherited from interface com.illumon.iris.db.util.liveness.LivenessReferentdropReference, getReferentDescription, getWeakReference, retainReference, tryRetainReferenceMethods inherited from interface com.illumon.iris.db.v2.TableMapasTableMap, deflate, transformTables, transformTablesMethods inherited from interface com.illumon.iris.db.v2.TransformableTableMapasTable, asTableBuilder
- 
Constructor Details
- 
Method Details- 
getDescription copied from interface:TableMapGets a table with a given key. Note that this causes the currentLivenessManager(seeLivenessScopeStack) to manage the result if non-null.- Parameters:
- key- key
- Returns:
- table associated with the key, or null if the key is not present.
 
- 
getWithTransformDescription copied from interface:TableMapGets a table with a given key, applying the specified transform before returning.- Parameters:
- key- key
- Returns:
- table associated with the key, or null if the key is not present.
 
- 
getKeySetDescription copied from interface:TableMapGets the keys.- Returns:
- keys
 
- 
entrySetDescription copied from interface:TableMapGets the entries.- Returns:
- the entries
 
- 
valuesDescription copied from interface:TableMapGets the values.- Returns:
- values
 
- 
sizepublic int size()Description copied from interface:TableMapNumber of tables in the map.- Returns:
- number of tables in the map.
 
- 
populateKeysDescription copied from interface:TableMapWhen creating the table map, some of the keys that we would like to be there eventually may not exist. This call lets you pre-populate keys, so that at initialization time you can perform the appropriate joins, etc., on empty tables that you expect to be populated in the future.- Parameters:
- keys- the keys to add to the map
- Returns:
- this TableMap
 
- 
flattenDescription copied from interface:TableMapFlattens all of the result tables within the tablemap.
- 
preemptiveUpdatesTableDescription copied from interface:TableMapCreates preemptive tables out of all of the result tables within the tablemap.- Parameters:
- intervalMillis- update interval for the preemptive tables
 
- 
applyDescription copied from interface:TableMapApplies a function to this tableMap. This is useful if you have a reference to a tableMap; but not the database and want to run a series of operations against the table map without each individual operation resulting in a remote method invocation.- Type Parameters:
- R- the return type of function
- Parameters:
- function- the function to run, its single argument will be this table map.
- Returns:
- the return value of function
 
- 
transformTablesWithKeyDescription copied from interface:TableMapApplies a transformation function on all tables in the TableMap, producing a new TableMap which will update as new keys are added.The function may be passed a sentinel key, which can be checked with TableMap.isSentinel(Object). On the sentinel key, the function will be passed in an empty table, and is expected to return an empty table of the proper definition. To avoid this sentinel invocation, callers can be explicit and useTableMap.transformTablesWithKey(TableDefinition, BiFunction).- Parameters:
- function- the bifunction to apply to each table in this TableMap
- Returns:
- a new TableMap where each table has had function applied
 
- 
transformTablesWithKeypublic TableMap transformTablesWithKey(TableDefinition returnDefinition, BiFunction<Object,Table,Table> function)Description copied from interface:TableMapApplies a transformation function on all tables in the TableMap, producing a new TableMap which will update as new keys are added.- Parameters:
- returnDefinition- the table definition for the tables the function will return
- function- the bifunction to apply to each table in this TableMap
- Returns:
- a new TableMap where each table has had function applied
 
- 
transformTablesWithMappublic TableMap transformTablesWithMap(TableMap otherMap, BiFunction<Table,Table,Table> function)Description copied from interface:TableMapApplies a BiFunction function on all tables in this TableMap and otherMap that have matching keys, producing a new TableMap which will update as new keys are added. Only applies the function to tables which exist in both maps.- Parameters:
- otherMap- the other TableMap
- function- the function to apply to each table in this TableMap, the tables in this map are the first argument the tables in the other map are the second argument.
- Returns:
- a new TableMap where each table has had function applied
 
- 
asTableDescription copied from interface:TransformableTableMapCreate a Table out of this TableMap's values.Creates a proxy object that in many respects acts like a Table, you can perform many of the table operations on it, which are then applied using TableMap.transformTables(java.util.function.Function)orTableMap.transformTablesWithMap(TableMap, BiFunction)if the right hand side of an operation is another TableMap.The returned table acts as if it were an uncoalesced table; when two of our Proxy objects are operated on together, e.g., by a Table.join(com.illumon.iris.db.tables.Table)) operation, then tables with identical keys are used. If strictKeys is set, an error occurs if the two TableMaps do not have identical keySets.Supported operations include those which return a Table,LongSizedDataStructure.size(),Table.getDefinition()and operations to retrieve attributes. Operations which retrieve data (such asTable.getIndex()} orTable.getColumn(int)require a coalesce operation. If allowCoalesce is not set to true, then the coalescing operations will fail with anIllegalArgumentException.- Parameters:
- strictKeys- if we should fail when our RHS TableMap does not have the same keySet
- allowCoalesce- if we should allow this TableMap to be automatically coalesced into a table
- sanityCheckJoins- if we should sanity check join keys, meaning that we should refuse to perform any joins if the join keys would span two segments of the TableMap. This option is safer, but requires additional work on the query engine to perform the safety checks.
- Returns:
- a Table object that performs operations by segment
 
- 
mergeDescription copied from interface:TransformableTableMapMerges all of the component tables into a single Table.- Returns:
- all of our component tables merged into a single Table.
 
- 
getIdpublic int getId()
- 
onKeyAddition
- 
initializeTransientFieldsForLivenessPackage-private forSerializablesub-classes to use inreadObjectonly. Public to allow unit tests in another package to work around mock issues where the constructor is never invoked.
- 
tryRetainReferencepublic final boolean tryRetainReference()Description copied from interface:LivenessReferentIf this referent is "live", behave asLivenessReferent.retainReference()and return true. Otherwise, returns false rather than throwing an exception.- Specified by:
- tryRetainReferencein interface- LivenessReferent
- Returns:
- True if this referent was retained, false otherwise
 
- 
dropReferencepublic final void dropReference()Description copied from interface:LivenessReferentDrop a previously-retained reference to this referent.- Specified by:
- dropReferencein interface- LivenessReferent
 
- 
getWeakReferenceDescription copied from interface:LivenessReferentGet aWeakReferenceto this referent. This may be cached, or newly created.- Specified by:
- getWeakReferencein interface- LivenessReferent
- Returns:
- A new or cached reference to this referent
 
- 
tryManageDescription copied from interface:LivenessManagerAttempt to add the specified referent to this manager.- Specified by:
- tryManagein interface- LivenessManager
- Parameters:
- referent- The referent to add
- Returns:
- Whether the referent was in fact added
 
- 
onReferenceCountAtZeroprotected final void onReferenceCountAtZero()Description copied from class:ReferenceCountedCallback method that will be invoked when the reference count returns to zero.- Specified by:
- onReferenceCountAtZeroin class- ReferenceCounted
 
 
-