Class TableMapClient
- All Implemented Interfaces:
com.fishlib.base.log.LogOutputAppendable
,Deflatable<TableMap>
,LivenessManager
,LivenessNode
,LivenessReferent
,DynamicNode
,TableMap
,TransformableTableMap
,Serializable
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic class
Get a table from aTableMap
applying approriate ACLs before returningstatic class
static class
Get a merged table of multiple keys from aTableMap
applying approriate ACLs before returningstatic class
Nested classes/interfaces inherited from interface com.illumon.iris.db.v2.TableMap
TableMap.KeyListener, TableMap.Listener
Nested classes/interfaces inherited from interface com.illumon.iris.db.v2.TransformableTableMap
TransformableTableMap.AsTableBuilder
-
Field Summary
Fields inherited from interface com.illumon.iris.db.v2.TableMap
SENTINEL_KEY
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescription<R> R
Applies a function to this tableMap.asTable
(boolean strictKeys, boolean allowCoalesce, boolean sanityCheckJoins) Create a Table out of this TableMap's values.entrySet()
Gets the entries.flatten()
Flattens all of the result tables within the tablemap.Gets a table with a given key.int
getId()
Object[]
Gets the keys.getWithTransform
(Object key, Function<Table, Table> transform) Gets a table with a given key, applying the specified transform before returning.merge()
Merges all of the component tables into a single Table.void
onKeyAddition
(Object key) populateKeys
(Object... keys) When creating the table map, some of the keys that we would like to be there eventually may not exist.preemptiveUpdatesTable
(int intervalMillis) Creates preemptive tables out of all of the result tables within the tablemap.int
size()
Number of tables in the map.transformTablesWithKey
(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.transformTablesWithKey
(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.transformTablesWithMap
(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.values()
Gets the values.Methods inherited from class com.illumon.iris.db.v2.TableMapImpl
addKeyListener, addListener, addParentReference, destroy, isRefreshing, notifyKeyListeners, notifyListeners, removeKeyListener, removeListener, setRefreshing
Methods inherited from class com.illumon.iris.db.util.liveness.LivenessArtifact
manageWithCurrentScope, unmanage, unmanage
Methods inherited from class com.illumon.iris.db.util.liveness.ReferenceCountedLivenessNode
dropReference, getWeakReference, initializeTransientFieldsForLiveness, onReferenceCountAtZero, tryManage, tryRetainReference
Methods inherited from class com.illumon.util.referencecounting.ReferenceCounted
append, decrementReferenceCount, incrementReferenceCount, resetReferenceCount, toString, tryDecrementReferenceCount, tryIncrementReferenceCount
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface com.illumon.iris.db.util.liveness.LivenessManager
manage, tryManage
Methods inherited from interface com.illumon.iris.db.util.liveness.LivenessReferent
dropReference, getReferentDescription, getWeakReference, retainReference, tryRetainReference
Methods inherited from interface com.illumon.iris.db.v2.TableMap
asTableMap, deflate, transformTables, transformTables
Methods inherited from interface com.illumon.iris.db.v2.TransformableTableMap
asTable, asTableBuilder
-
Constructor Details
-
TableMapClient
-
-
Method Details
-
get
Description copied from interface:TableMap
Gets 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.
-
getWithTransform
Description copied from interface:TableMap
Gets 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.
-
getKeySet
Description copied from interface:TableMap
Gets the keys.- Returns:
- keys
-
entrySet
Description copied from interface:TableMap
Gets the entries.- Returns:
- the entries
-
values
Description copied from interface:TableMap
Gets the values.- Returns:
- values
-
size
public int size()Description copied from interface:TableMap
Number of tables in the map.- Returns:
- number of tables in the map.
-
populateKeys
Description copied from interface:TableMap
When 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
-
flatten
Description copied from interface:TableMap
Flattens all of the result tables within the tablemap. -
preemptiveUpdatesTable
Description copied from interface:TableMap
Creates preemptive tables out of all of the result tables within the tablemap.- Parameters:
intervalMillis
- update interval for the preemptive tables
-
apply
Description copied from interface:TableMap
Applies 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
-
transformTablesWithKey
Description copied from interface:TableMap
Applies 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
-
transformTablesWithKey
public TableMap transformTablesWithKey(TableDefinition returnDefinition, BiFunction<Object, Table, Table> function) Description copied from interface:TableMap
Applies 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 returnfunction
- the bifunction to apply to each table in this TableMap- Returns:
- a new TableMap where each table has had function applied
-
transformTablesWithMap
Description copied from interface:TableMap
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. Only applies the function to tables which exist in both maps.- Parameters:
otherMap
- the other TableMapfunction
- 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
-
asTable
Description copied from interface:TransformableTableMap
Create 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 keySetallowCoalesce
- if we should allow this TableMap to be automatically coalesced into a tablesanityCheckJoins
- 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
-
merge
Description copied from interface:TransformableTableMap
Merges all of the component tables into a single Table.- Returns:
- all of our component tables merged into a single Table.
-
getId
public int getId() -
onKeyAddition
-