Class UnimplementedDatabase
- All Implemented Interfaces:
- Database
DatabaseInternal
 and the enterprise version. Everything will return an UnsupportedOperationException.- 
Nested Class SummaryNested classes/interfaces inherited from interface com.illumon.iris.db.tables.databases.DatabaseDatabase.LogHandle, Database.StorageFormat
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddPartitionedTableDefinition(String namespace, String tableName, TableDefinition prototypeDefinition) Adds a table definition for a partitioned table.voidaddPartitionedTableDefinition(String namespace, String tableName, String partitioningColumnName, TableDefinition prototypeDefinition) Adds a table definition for a partitioned table.voidaddPartitionedTableDefinitionIfAbsent(String namespace, String tableName, String partitioningColumnName, TableDefinition prototypeDefinition) Adds a table definition for a partitioned table, if the table definition is absent.voidaddPartitionedTableDefinitionIfAbsent(String namespace, String tableName, String partitioningColumnName, TableDefinition prototypeDefinition, boolean checkPartitioningColumn) Adds a table definition for a partitioned table, if the table definition is absent.voidaddTable(String namespace, String tableName, Table table, Database.StorageFormat storageFormat) Adds a non-partitioned table by name to the specified namespace.voidaddTableDefinition(String namespace, String tableName, TableDefinition tableDefinition) Adds a table definition to the specified namespace.voidaddTablePartition(String namespace, String tableName, String columnPartitionValue, Table data, Database.StorageFormat storageFormat) Adds a single table partition (e.g.voidaddTablePartition(String namespace, String tableName, String internalPartitionValue, String columnPartitionValue, Table data, Database.StorageFormat storageFormat) Adds a single table partition (e.g.voidaddTablePartitionAndDefinition(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table data) Adds a table definition and data for a partitioned user table location.voidaddTablePartitionAndDefinition(String namespace, String tableName, String partitioningColumnName, String internalPartitionValue, String columnPartitionValue, Table data) Adds a table definition and data for a partitioned table.voidappendCentral(String namespace, String tableName, Table table, boolean flush) Append to a table via a centralized table appender.voidappendCentral(String namespace, String tableName, String columnPartitionValue, Table table, boolean flush) Atomically append to a table via a centralized table appender.voidappendTable(String namespace, String tableName, Table table) Appends to a non-partitioned table, or adds the table if it is not present.voidappendTablePartition(String namespace, String tableName, String columnPartitionValue, Table data) Adds or appends to a single table location (e.g.voidappendTablePartition(String namespace, String tableName, String internalPartitionValue, String columnPartitionValue, Table data) Adds or appends to a single table location (e.g.voidcloseAndDeleteCentral(String namespace, String tableName) Close all logger connections to the centralized logging for the specified table, and then atomically delete all centrally logged table data for this namespace and table name.voidcloseAndDeleteCentral(String namespace, String tableName, String columnPartitionValue) Close all logger connections to the centralized logging for the specified table, and then atomically delete all centrally logged table data for this namespace and table name, restricted to the column partition value if provided.voiddeleteMatchingTables(String namespace, String tableNameRegex) Delete all files related to the set of tables whose names match the supplied regular expression.voiddeleteNamespace(String namespace) Delete all files related to the specified namespace.voiddeleteTables(String namespace, String... tableNames) Delete all files related to a set of tables.<T> TexecuteQuery(RemoteQuery<T> remoteQuery, Class<?>... additionalClasses) Executes a DB query.voidgc()Invoke the garbage collector for this database.Gets a table containing information on all tables in the DB.Gets a client hostname.getColumnPartitionTableWriter(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, TableDefinition tableDefinition, boolean append) Gets a local table writer for a partitioned table.Get an error log for the DB.getIntradayPartitions(String namespace, String tableName) Get a list of all internal partition values available for the specified intraday table.getIntradayPartitionsAsTable(String namespace, String tableName) Get all internal partition values available for the specified intraday table, returned as table.getIntradayTableV2(String namespace, String tableName, boolean live) Retrieves an intraday table by namespace and name.getIntradayTableV2(String namespace, String tableName, Set<String> internalPartitionValues, boolean live) Retrieves the specified internal partitions of the specified intraday table.getLastByTable(String namespace, String tableName) Retrieves an intraday last-by table by namespace and name.Retrieves all namespace names from the database.Gets the unique processInfoId of the worker.getReplayer(DBDateTime timeStart, DBDateTime timeEnd) Creates a data replayer.getReplayer(DBDateTime timeStart, DBDateTime timeEnd, long interval) Creates a data replayer.Gets the server hostname.Retrieves system namespace names from the database.getTableDefinition(String namespace, String tableName) Retrieves a table definition by namespace and name, generally from the schema service.getTableNames(String namespace) Gets all table names from the specified namespace.getTableV2(String namespace, String tableName) Retrieves a table by namespace and name.getTableWriter(String namespace, String tableName, TableDefinition tableDefinition, boolean append) Gets a local table writer for an unpartitioned table.Retrieves user namespace names from the database.Gets the worker name.booleanhasImportedData(String namespace, String tableName, String columnPartitionValue) Determines if the historical table's column partition is present in the DB.booleanhasIntradayData(String namespace, String tableName, String columnPartitionValue) Determines if the intraday table's column partition is present in the DB.booleanhasIntradayTable(String namespace, String tableName) Determines if the table is present in the DB and currently has intraday data.booleanhasNamespace(String namespace) Determines if the namespace is present in the DB.booleanDetermines if the table is defined in the DB.voidimportClass(Class classToImport) Imports a class for use in a query.voidimportStatic(Class classToImport) Imports the static methods from a class for use in a query.logPartitionTableIncremental(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, boolean append) Writes all changes in a table to a local table.logPartitionTableIncremental(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, ReplayerInterface replayer, boolean append) Writes all changes in a table to a local table.logPartitionTableSnapshot(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, long logIntervalMillis, boolean append) Snapshots a table at a regular interval and writes the snapshot to a local table.logPartitionTableSnapshot(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, long logIntervalMillis, ReplayerInterface replayer, boolean append) Snapshots a table at a regular interval and writes the snapshot to a local table.logPartitionTableSnapshot(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, String logInterval, boolean append) Snapshots a table at a regular interval and writes the snapshot to a local table.logPartitionTableSnapshot(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, String logInterval, ReplayerInterface replayer, boolean append) Snapshots a table at a regular interval and writes the snapshot to a local table.makeRemote(Table value) Make a copy of a local table on a remote server.Convenience method forDatabase.makeRemote(Table).
 Make a copy of a local table on a remote server.voidReload any internally-cached data.voidremoveTable(String namespace, String tableName) Removes a table.voidremoveTableDefinition(String namespace, String tableName) Removes a table definition.voidremoveTablePartition(String namespace, String tableName, String columnPartitionValue) Removes a single table location (e.g.voidremoveTablePartition(String namespace, String tableName, String internalPartitionValue, String columnPartitionValue) Removes a single table location (e.g.voidreplaceTable(String namespace, String tableName, Table table, Database.StorageFormat storageFormat) Replaces a non-partitioned table with a new table, or adds the table, if it is not already present.voidreplaceTableDefinition(String namespace, String tableName, TableDefinition tableDefinition) Replaces a user table definition.voidreplaceTablePartition(String namespace, String tableName, String columnPartitionValue, Table data, Database.StorageFormat storageFormat) Removes and re-adds a single table location (e.g.voidreplaceTablePartition(String namespace, String tableName, String internalPartitionValue, String columnPartitionValue, Table data, Database.StorageFormat storageFormat) Replaces a single table location (e.g.intsetWatchdogMillis(int millis) Sets monitoring of delays in the LiveTableMonitor refresh loop.voidsetWatchdogTimeoutProcedure(LongConsumer watchdogTimeoutProcedure) Set the watchdog timeout procedure.voidshutdown()Shuts this database down.voidstartup()Starts this database up.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.illumon.iris.db.tables.databases.DatabaseaddColumnPartitionAndDefinition, addColumnPartitionAndDefinition, addTable, addTablePartition, addTablePartition, getIntradayTable, getIntradayTable, getIntradayTable, getIntradayTable, getIntradayTable, getIntradayTable, getIntradayTableV2, getIntradayTableV2, getIntradayTableV2, getIntradayTableV2, getReplayer, getReplayer, getReplayer, getTable, getUserContext, i, i, i, i, i, i, i2, i2, i2, i2, i2, i2, replaceTable, replaceTablePartition, replaceTablePartition, rm, t, t2, timeTable, timeTable, timeTable, timeTable, timeTable, timeTable, timeTable, timeTable, timeTable, timeTable, timeTable, timeTable
- 
Constructor Details- 
UnimplementedDatabasepublic UnimplementedDatabase()
 
- 
- 
Method Details- 
getWorkerNameDescription copied from interface:DatabaseGets the worker name.- Specified by:
- getWorkerNamein interface- Database
- Returns:
- worker name
 
- 
getProcessInfoIdDescription copied from interface:DatabaseGets the unique processInfoId of the worker.- Specified by:
- getProcessInfoIdin interface- Database
- Returns:
- process info id
 
- 
getClientHostDescription copied from interface:DatabaseGets a client hostname.- Specified by:
- getClientHostin interface- Database
- Returns:
- client hostname
 
- 
getServerHostDescription copied from interface:DatabaseGets the server hostname.- Specified by:
- getServerHostin interface- Database
- Returns:
- server hostname.
 
- 
startuppublic void startup()Description copied from interface:DatabaseStarts this database up.
- 
shutdownpublic void shutdown()Description copied from interface:DatabaseShuts this database down.
- 
reloadDatapublic void reloadData()Description copied from interface:DatabaseReload any internally-cached data.- Specified by:
- reloadDatain interface- Database
 
- 
gcpublic void gc()Description copied from interface:DatabaseInvoke the garbage collector for this database.
- 
getErrorLogDescription copied from interface:DatabaseGet an error log for the DB. This is a real-time table.- Specified by:
- getErrorLogin interface- Database
- Returns:
- error log
- Throws:
- Exception- problems retrieving the error log.
 
- 
setWatchdogMillisDescription copied from interface:DatabaseSets monitoring of delays in the LiveTableMonitor refresh loop. If the LiveTableMonitor refresh loop takes longer than the specified amount of time, the watchdog timeout procedure is executed. The watchdog timeout procedure is specified by callingDatabase.setWatchdogTimeoutProcedure(LongConsumer).- Specified by:
- setWatchdogMillisin interface- Database
- Parameters:
- millis- if LiveTableMonitor refresh loop takes longer than this amount of time, the watchdog timeout procedure will be called.
- Returns:
- the new value of the watchdog timer, in ms
- Throws:
- IOException- problems setting the monitor interval
 
- 
setWatchdogTimeoutProcedureDescription copied from interface:DatabaseSet the watchdog timeout procedure. If LiveTableMonitor refresh loop takes longer than the amount of time specified viaDatabase.setWatchdogMillis(int), the timeout procedure is called.- Specified by:
- setWatchdogTimeoutProcedurein interface- Database
- Parameters:
- watchdogTimeoutProcedure- the procedure called when the LiveTableMonitor refresh loop takes longer than watchdogMillis.
- Throws:
- IOException
 
- 
executeQuerypublic <T> T executeQuery(RemoteQuery<T> remoteQuery, Class<?>... additionalClasses) throws IOException Description copied from interface:DatabaseExecutes a DB query.- Specified by:
- executeQueryin interface- Database
- Type Parameters:
- T- return type
- Parameters:
- remoteQuery- query to execute
- additionalClasses- additional classes to use during the query
- Returns:
- result of the query (must be serializable)
- Throws:
- IOException- problems executing the query or transmitting results
 
- 
importClassDescription copied from interface:DatabaseImports a class for use in a query. For example:db.importClass(X.class) t=db.t(namespace,tablename).where("X.func(A)")- Specified by:
- importClassin interface- Database
- Parameters:
- classToImport- the class
 
- 
importStaticDescription copied from interface:DatabaseImports the static methods from a class for use in a query. For example:db.importStaticClass(X.class) t=db.t(namespace,tablename).where("staticFunc(A)")where staticFuncis a static function ofX.- Specified by:
- importStaticin interface- Database
- Parameters:
- classToImport- The class
 
- 
mrDescription copied from interface:DatabaseConvenience method forDatabase.makeRemote(Table).
 Make a copy of a local table on a remote server.
- 
makeRemoteDescription copied from interface:DatabaseMake a copy of a local table on a remote server.- Specified by:
- makeRemotein interface- Database
- Parameters:
- value- local table
- Returns:
- remote table.
 
- 
getReplayerDescription copied from interface:DatabaseCreates a data replayer.- Specified by:
- getReplayerin interface- Database
- Parameters:
- timeStart- replay start time
- timeEnd- replay end time
- Returns:
- replayer
- Throws:
- IOException- problems creating the replayer
 
- 
getReplayerpublic ReplayerInterface getReplayer(DBDateTime timeStart, DBDateTime timeEnd, long interval) throws Exception Description copied from interface:DatabaseCreates a data replayer.- Specified by:
- getReplayerin interface- Database
- Parameters:
- timeStart- replay start time
- timeEnd- replay end time
- interval- replay step size
- Returns:
- replayer
- Throws:
- IOException- problems creating the replayer
- Exception
 
- 
getSystemNamespacesDescription copied from interface:DatabaseRetrieves system namespace names from the database.- Specified by:
- getSystemNamespacesin interface- Database
- Returns:
- The list of namespace names
 
- 
getUserNamespacesDescription copied from interface:DatabaseRetrieves user namespace names from the database.- Specified by:
- getUserNamespacesin interface- Database
- Returns:
- The list of namespace names
 
- 
getNamespacesDescription copied from interface:DatabaseRetrieves all namespace names from the database.- Specified by:
- getNamespacesin interface- Database
- Returns:
- The list of namespace names
 
- 
hasNamespaceDescription copied from interface:DatabaseDetermines if the namespace is present in the DB.- Specified by:
- hasNamespacein interface- Database
- Parameters:
- namespace- namespace
- Returns:
- true if the namespace exists; false otherwise.
 
- 
getCatalogDescription copied from interface:DatabaseGets a table containing information on all tables in the DB.- Specified by:
- getCatalogin interface- Database
- Returns:
- table containing information on all tables in the DB
 
- 
getTableNamesDescription copied from interface:DatabaseGets all table names from the specified namespace.- Specified by:
- getTableNamesin interface- Database
- Parameters:
- namespace- The namespace to list the contents of
- Returns:
- The list of table names
 
- 
hasTableDescription copied from interface:DatabaseDetermines if the table is defined in the DB.
- 
hasIntradayTableDescription copied from interface:DatabaseDetermines if the table is present in the DB and currently has intraday data.- Specified by:
- hasIntradayTablein interface- Database
- Parameters:
- namespace- namespace
- tableName- table name
- Returns:
- true if the table exists and has intraday data; false otherwise.
 
- 
getTableDefinitionDescription copied from interface:DatabaseRetrieves a table definition by namespace and name, generally from the schema service.- Specified by:
- getTableDefinitionin interface- Database
- Parameters:
- namespace- The namespace of the definition to retrieve
- tableName- The table name of the definition to retrieve
- Returns:
- The table definition retrieved, null if not found
 
- 
getIntradayPartitionsDescription copied from interface:DatabaseGet a list of all internal partition values available for the specified intraday table.- Specified by:
- getIntradayPartitionsin interface- Database
- Parameters:
- namespace- The namespace of the table
- tableName- The table name to examine in the intraday data space
- Returns:
- A list of internal partition values for top-level partitioning of the intraday table. Typically represents one partition per source.
 
- 
getIntradayPartitionsAsTableDescription copied from interface:DatabaseGet all internal partition values available for the specified intraday table, returned as table.- Specified by:
- getIntradayPartitionsAsTablein interface- Database
- Parameters:
- namespace- The namespace of the table
- tableName- The table name to examine in the intraday data space
- Returns:
- A table containing the internal partition values for top-level partitioning of the intraday table. Typically represents one partition per source.
 
- 
hasImportedDataDescription copied from interface:DatabaseDetermines if the historical table's column partition is present in the DB.- Specified by:
- hasImportedDatain interface- Database
- Parameters:
- namespace- namespace
- tableName- table name
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- Returns:
- true if the table's column partition exists; false otherwise.
 
- 
hasIntradayDataDescription copied from interface:DatabaseDetermines if the intraday table's column partition is present in the DB.- Specified by:
- hasIntradayDatain interface- Database
- Parameters:
- namespace- namespace
- tableName- table name
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- Returns:
- true if the intraday table's column partition exists; false otherwise.
 
- 
getSchemaServiceDescription copied from interface:Database- Specified by:
- getSchemaServicein interface- Database
- Returns:
- The SchemaServicethat thisDatabasewas created with.
 
- 
getTableV2Description copied from interface:DatabaseRetrieves a table by namespace and name. Throws exceptions for unknown tables.- Specified by:
- getTableV2in interface- Database
- Parameters:
- namespace- namespace of the table
- tableName- name of the table
- Returns:
- table in "v2" format
 
- 
getIntradayTableV2Description copied from interface:DatabaseRetrieves an intraday table by namespace and name. Throws exceptions for unknown tables.- Specified by:
- getIntradayTableV2in interface- Database
- Parameters:
- namespace- namespace of the table
- tableName- name of the table
- live- true if the table should be live/updating; false otherwise
- Returns:
- intraday table
 
- 
getIntradayTableV2public Table getIntradayTableV2(String namespace, String tableName, Set<String> internalPartitionValues, boolean live) Description copied from interface:DatabaseRetrieves the specified internal partitions of the specified intraday table. The result may contain locations for multiple column partition values, and so a subsequent filter (e.g. on "Date") will often be desired.Throws exceptions for unknown tables. - Specified by:
- getIntradayTableV2in interface- Database
- Parameters:
- namespace- namespace of the table
- tableName- name of the table
- internalPartitionValues- locations will be restricted to these internal partition values
- live- true if the table should be live/updating; false otherwise
- Returns:
- single partition intraday table
 
- 
getLastByTableDescription copied from interface:DatabaseRetrieves an intraday last-by table by namespace and name.Throws exceptions for unknown tables. Always provides a live result. This may not be configured on your system. - Specified by:
- getLastByTablein interface- Database
- Parameters:
- namespace- namespace of the table
- tableName- name of the table
- Returns:
- live intraday last-by table
 
- 
deleteNamespaceDescription copied from interface:DatabaseDelete all files related to the specified namespace.Note: This is a dangerous API - don't use it if you don't fully understand the implications. - Specified by:
- deleteNamespacein interface- Database
- Parameters:
- namespace- namespace to be deleted.
 
- 
deleteTablesDescription copied from interface:DatabaseDelete all files related to a set of tables.Database.removeTable(String, String)is a better option, unless the underlying table is damaged.- Specified by:
- deleteTablesin interface- Database
- Parameters:
- namespace- table namespace
- tableNames- table names to delete
 
- 
deleteMatchingTablesDescription copied from interface:DatabaseDelete all files related to the set of tables whose names match the supplied regular expression.Note: This only works for tables that still have a definition file, although it need not be readable. Note: This is a dangerous API - don't use it if you don't fully understand the implications. - Specified by:
- deleteMatchingTablesin interface- Database
- Parameters:
- namespace- table namespace
- tableNameRegex- table names in the given namespace that match this regular expression will be cleaned up.
 
- 
addTablepublic void addTable(String namespace, String tableName, Table table, Database.StorageFormat storageFormat) Description copied from interface:DatabaseAdds a non-partitioned table by name to the specified namespace.
- 
appendTableDescription copied from interface:DatabaseAppends to a non-partitioned table, or adds the table if it is not present. Adds a TableDefinition if necessary.- Specified by:
- appendTablein interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- table- data to add or append
 
- 
removeTableDescription copied from interface:DatabaseRemoves a table. This method is a better choice thanDatabase.deleteTables(String, String...), unless the underlying table no longer has consistent metadata. Throws an exception for tables that don't exist.- Specified by:
- removeTablein interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
 
- 
replaceTablepublic void replaceTable(String namespace, String tableName, Table table, Database.StorageFormat storageFormat) Description copied from interface:DatabaseReplaces a non-partitioned table with a new table, or adds the table, if it is not already present. Not guaranteed to be atomic in the case of failures.- Specified by:
- replaceTablein interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- table- data for the replacement table
- storageFormat- the storage format to use (ex DeephavenV1 or Parquet)
 
- 
addTableDefinitionDescription copied from interface:DatabaseAdds a table definition to the specified namespace. Throws an exception if the table definition already exists.- Specified by:
- addTableDefinitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- tableDefinition- table definition to add
 
- 
removeTableDefinitionDescription copied from interface:DatabaseRemoves a table definition.- Specified by:
- removeTableDefinitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
 
- 
replaceTableDefinitionpublic void replaceTableDefinition(String namespace, String tableName, TableDefinition tableDefinition) Description copied from interface:DatabaseReplaces a user table definition.Not guaranteed to be atomic in the case of failures. Does not throw an exception for tables that don't exist. - Specified by:
- replaceTableDefinitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- tableDefinition- table definition for the replacement
 
- 
addTablePartitionpublic void addTablePartition(String namespace, String tableName, String columnPartitionValue, Table data, Database.StorageFormat storageFormat) Description copied from interface:DatabaseAdds a single table partition (e.g. one date) to a partitioned table.Requires that a suitable TableDefinition has already been added. This variant implicitly uses internalPartitionValue set by the iris.defaultInternalPartitionNamingFunctionproperty.Throws an exception if the partition already exists. - Specified by:
- addTablePartitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- data- data for this partition. Must *not* contain the partitioning column.
- storageFormat- the format used for storage
 
- 
addTablePartitionpublic void addTablePartition(String namespace, String tableName, String internalPartitionValue, String columnPartitionValue, Table data, Database.StorageFormat storageFormat) Description copied from interface:DatabaseAdds a single table partition (e.g. one date) to a partitioned table.Requires that a suitable TableDefinition has already been added. Throws an exception if the partition already exists. - Specified by:
- addTablePartitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- internalPartitionValue- internal (not user-visible) partition value.
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- data- data for this partition. Must *not* contain the partitioning column.
- storageFormat- the format used for storage
 
- 
appendTablePartitionpublic void appendTablePartition(String namespace, String tableName, String columnPartitionValue, Table data) Description copied from interface:DatabaseAdds or appends to a single table location (e.g. one date) to a partitioned user table.Requires that a suitable TableDefinition has already been added. This variant implicitly uses internalPartitionName set by the iris.defaultInternalPartitionNamingFunctionproperty.- Specified by:
- appendTablePartitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- data- data to append to this partition. Must *not* contain the partitioning column.
 
- 
appendTablePartitionpublic void appendTablePartition(String namespace, String tableName, String internalPartitionValue, String columnPartitionValue, Table data) Description copied from interface:DatabaseAdds or appends to a single table location (e.g. one date) to a partitioned table.Requires that a suitable TableDefinition has already been added. - Specified by:
- appendTablePartitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- internalPartitionValue- internal (not user-visible) partition value.
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- data- data to append to this partition. Must *not* contain the partitioning column.
 
- 
removeTablePartitionDescription copied from interface:DatabaseRemoves a single table location (e.g. one date) from a partitioned user table.Requires that a suitable TableDefinition still exists. This variant implicitly uses internalPartitionValue set by the iris.defaultInternalPartitionNamingFunctionproperty.- Specified by:
- removeTablePartitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
 
- 
removeTablePartitionpublic void removeTablePartition(String namespace, String tableName, String internalPartitionValue, String columnPartitionValue) Description copied from interface:DatabaseRemoves a single table location (e.g. one date) from a partitioned table. Requires that a suitable TableDefinition still exists.- Specified by:
- removeTablePartitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- internalPartitionValue- internal (not user-visible) partition value.
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
 
- 
replaceTablePartitionpublic void replaceTablePartition(String namespace, String tableName, String columnPartitionValue, Table data, Database.StorageFormat storageFormat) Description copied from interface:DatabaseRemoves and re-adds a single table location (e.g. one date) from/to a partitioned table.Requires that a suitable TableDefinition has already been added. This variant implicitly uses internalPartitionName set by the iris.defaultInternalPartitionNamingFunctionproperty.Not guaranteed to be atomic in the case of failures. - Specified by:
- replaceTablePartitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- data- data for this partition. Must *not* contain the partitioning column.
- storageFormat- the storage format to use (ex DeephavenV1 or Parquet)
 
- 
replaceTablePartitionpublic void replaceTablePartition(String namespace, String tableName, String internalPartitionValue, String columnPartitionValue, Table data, Database.StorageFormat storageFormat) Description copied from interface:DatabaseReplaces a single table location (e.g. one date) from/to a partitioned table.Requires that a suitable TableDefinition has already been added. Not guaranteed to be atomic in the case of failures. - Specified by:
- replaceTablePartitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- internalPartitionValue- internal (not user-visible) partition value.
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- data- data to replace this partition. Must *not* contain the partitioning column.
- storageFormat- the storage format to use (ex DeephavenV1 or Parquet)
 
- 
addPartitionedTableDefinitionIfAbsentpublic void addPartitionedTableDefinitionIfAbsent(@NotNull String namespace, @NotNull String tableName, @NotNull String partitioningColumnName, @NotNull TableDefinition prototypeDefinition) Description copied from interface:DatabaseAdds a table definition for a partitioned table, if the table definition is absent.- Specified by:
- addPartitionedTableDefinitionIfAbsentin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- prototypeDefinition- prototype table definition used to generate the table definition
 
- 
addPartitionedTableDefinitionIfAbsentpublic void addPartitionedTableDefinitionIfAbsent(@NotNull String namespace, @NotNull String tableName, @NotNull String partitioningColumnName, @NotNull TableDefinition prototypeDefinition, boolean checkPartitioningColumn) Description copied from interface:DatabaseAdds a table definition for a partitioned table, if the table definition is absent.- Specified by:
- addPartitionedTableDefinitionIfAbsentin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- prototypeDefinition- prototype table definition used to generate the table definition
- checkPartitioningColumn- true to make sure the partitioning columns are the same
 
- 
addPartitionedTableDefinitionpublic void addPartitionedTableDefinition(@NotNull String namespace, @NotNull String tableName, @NotNull String partitioningColumnName, @NotNull TableDefinition prototypeDefinition) Description copied from interface:DatabaseAdds a table definition for a partitioned table.- Specified by:
- addPartitionedTableDefinitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- prototypeDefinition- prototype table definition used to generate the table definition
 
- 
addPartitionedTableDefinitionpublic void addPartitionedTableDefinition(@NotNull String namespace, @NotNull String tableName, @NotNull TableDefinition prototypeDefinition) Description copied from interface:DatabaseAdds a table definition for a partitioned table. The partitioning column depends on theiris.defaultColumnPartitionColumnNameproperty.- Specified by:
- addPartitionedTableDefinitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- prototypeDefinition- prototype table definition used to generate the table definition
 
- 
addTablePartitionAndDefinitionpublic void addTablePartitionAndDefinition(@NotNull String namespace, @NotNull String tableName, @NotNull String partitioningColumnName, @NotNull String internalPartitionValue, @NotNull String columnPartitionValue, @NotNull Table data) Description copied from interface:DatabaseAdds a table definition and data for a partitioned table.This operation is not atomic. - Specified by:
- addTablePartitionAndDefinitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- internalPartitionValue- internal (not user-visible) partition value.
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- data- table containing the data and table definition to write out
 
- 
addTablePartitionAndDefinitionpublic void addTablePartitionAndDefinition(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table data) Description copied from interface:DatabaseAdds a table definition and data for a partitioned user table location.This operation is not atomic. This variant implicitly uses internalPartitionName set by the iris.defaultInternalPartitionNamingFunctionproperty.- Specified by:
- addTablePartitionAndDefinitionin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- data- table containing the data and table definition to write out
 
- 
appendCentralpublic void appendCentral(@NotNull String namespace, @NotNull String tableName, @NotNull String columnPartitionValue, @NotNull Table table, boolean flush) throws IOException Description copied from interface:DatabaseAtomically append to a table via a centralized table appender. Tables larger than a configurable size limit will be rejected.Note: The table data is appended to a system-defined internal partition, and the specified column partition value. - Specified by:
- appendCentralin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- table- new data
- flush- true to flush the table to disk; false to wait for flushing (if the implementation supports waiting)
- Throws:
- IOException- problem appending
 
- 
appendCentralpublic void appendCentral(@NotNull String namespace, @NotNull String tableName, @NotNull Table table, boolean flush) throws IOException Description copied from interface:DatabaseAppend to a table via a centralized table appender. Tables larger than a configurable size limit will be rejected.This variant implicitly uses a default partitioning column value set by the iris.defaultColumnPartitionNamingFunctionfunction.- Specified by:
- appendCentralin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- table- new data
- flush- true to flush the table to disk; false to wait for flushing (if the implementation supports waiting)
- Throws:
- IOException- problem appending
 
- 
closeAndDeleteCentralpublic void closeAndDeleteCentral(@NotNull String namespace, @NotNull String tableName) throws IOException Description copied from interface:DatabaseClose all logger connections to the centralized logging for the specified table, and then atomically delete all centrally logged table data for this namespace and table name. Remove all local table data also, as withDatabase.removeTable(String, String).USE WITH EXTREME CAUTION!!! - Specified by:
- closeAndDeleteCentralin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- Throws:
- IOException- problems encountered
 
- 
closeAndDeleteCentralpublic void closeAndDeleteCentral(@NotNull String namespace, @NotNull String tableName, String columnPartitionValue) throws IOException Description copied from interface:DatabaseClose all logger connections to the centralized logging for the specified table, and then atomically delete all centrally logged table data for this namespace and table name, restricted to the column partition value if provided. Remove all local table data also, as withDatabase.removeTable(String, String).USE WITH EXTREME CAUTION!!! - Specified by:
- closeAndDeleteCentralin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- columnPartitionValue- optional column partition value
- Throws:
- IOException- problems encountered
 
- 
logPartitionTableSnapshotpublic Database.LogHandle logPartitionTableSnapshot(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, String logInterval, ReplayerInterface replayer, boolean append) throws Exception Description copied from interface:DatabaseSnapshots a table at a regular interval and writes the snapshot to a local table.- Specified by:
- logPartitionTableSnapshotin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- table- table to snapshot and log (does not contain the partition column)
- logInterval- interval to log snapshots at
- replayer- data replayer
- append- true to append to an existing partition; false to replace the existing partition.
- Returns:
- log handle
- Throws:
- Exception- problems
 
- 
logPartitionTableSnapshotpublic Database.LogHandle logPartitionTableSnapshot(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, String logInterval, boolean append) throws Exception Description copied from interface:DatabaseSnapshots a table at a regular interval and writes the snapshot to a local table.- Specified by:
- logPartitionTableSnapshotin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- table- table to snapshot and log (does not contain the partition column)
- logInterval- interval to log snapshots at
- append- true to append to an existing partition; false to replace the existing partition.
- Returns:
- log handle
- Throws:
- Exception- problems
 
- 
logPartitionTableSnapshotpublic Database.LogHandle logPartitionTableSnapshot(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, long logIntervalMillis, ReplayerInterface replayer, boolean append) throws IOException Description copied from interface:DatabaseSnapshots a table at a regular interval and writes the snapshot to a local table.- Specified by:
- logPartitionTableSnapshotin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- table- table to snapshot and log (does not contain the partition column)
- logIntervalMillis- interval in milliseconds to log snapshots at
- replayer- data replayer
- append- true to append to an existing partition; false to replace the existing partition.
- Returns:
- log handle
- Throws:
- IOException- problems
 
- 
logPartitionTableSnapshotpublic Database.LogHandle logPartitionTableSnapshot(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, long logIntervalMillis, boolean append) throws IOException Description copied from interface:DatabaseSnapshots a table at a regular interval and writes the snapshot to a local table.- Specified by:
- logPartitionTableSnapshotin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- table- table to snapshot and log (does not contain the partition column)
- logIntervalMillis- interval in milliseconds to log snapshots at
- append- true to append to an existing partition; false to replace the existing partition.
- Returns:
- log handle
- Throws:
- IOException- problems
 
- 
logPartitionTableIncrementalpublic Database.LogHandle logPartitionTableIncremental(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, ReplayerInterface replayer, boolean append) throws IOException Description copied from interface:DatabaseWrites all changes in a table to a local table.- Specified by:
- logPartitionTableIncrementalin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- table- table to log (does not contain the partition column)
- replayer- data replayer
- append- true to append to an existing partition; false to replace the existing partition.
- Returns:
- log handle
- Throws:
- IOException- problems
 
- 
logPartitionTableIncrementalpublic Database.LogHandle logPartitionTableIncremental(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, Table table, boolean append) throws IOException Description copied from interface:DatabaseWrites all changes in a table to a local table.- Specified by:
- logPartitionTableIncrementalin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- table- table to log (does not contain the partition column)
- append- true to append to an existing partition; false to replace the existing partition.
- Returns:
- log handle
- Throws:
- IOException- problems
 
- 
getColumnPartitionTableWriterpublic TableWriter getColumnPartitionTableWriter(String namespace, String tableName, String partitioningColumnName, String columnPartitionValue, TableDefinition tableDefinition, boolean append) Description copied from interface:DatabaseGets a local table writer for a partitioned table.- Specified by:
- getColumnPartitionTableWriterin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- partitioningColumnName- name of the partitioning column
- columnPartitionValue- column partition value (e.g. "2015-09-25" for a Date partitioning column).
- tableDefinition- table definition
- append- true to append to an existing partition; false to overwrite an existing partition.
- Returns:
- table writer
 
- 
getTableWriterpublic TableWriter getTableWriter(String namespace, String tableName, TableDefinition tableDefinition, boolean append) throws IOException Description copied from interface:DatabaseGets a local table writer for an unpartitioned table.- Specified by:
- getTableWriterin interface- Database
- Parameters:
- namespace- table namespace
- tableName- table name
- tableDefinition- table definition
- append- true to append to an existing partition; false to overwrite an existing partition.
- Returns:
- table writer
- Throws:
- IOException
 
 
-