Package adams.flow.transformer
Class BulkSampleDataDbWriter
- java.lang.Object
-
- adams.core.logging.LoggingObject
-
- adams.core.logging.CustomLoggingLevelObject
-
- adams.core.option.AbstractOptionHandler
-
- adams.flow.core.AbstractActor
-
- adams.flow.transformer.AbstractTransformer
-
- adams.flow.transformer.AbstractDbTransformer
-
- adams.flow.transformer.BulkSampleDataDbWriter
-
- All Implemented Interfaces:
adams.core.AdditionalInformationHandler
,adams.core.CleanUpHandler
,adams.core.Destroyable
,adams.core.GlobalInfoSupporter
,adams.core.logging.LoggingLevelHandler
,adams.core.logging.LoggingSupporter
,adams.core.option.OptionHandler
,adams.core.QuickInfoSupporter
,adams.core.ShallowCopySupporter<adams.flow.core.Actor>
,adams.core.SizeOfHandler
,adams.core.Stoppable
,adams.core.StoppableWithFeedback
,adams.core.VariablesInspectionHandler
,adams.db.DatabaseConnectionUser
,adams.event.VariableChangeListener
,adams.flow.core.Actor
,adams.flow.core.ErrorHandler
,adams.flow.core.InputConsumer
,adams.flow.core.OutputProducer
,SampleDataDatabaseWriter
,Serializable
,Comparable
public class BulkSampleDataDbWriter extends adams.flow.transformer.AbstractDbTransformer implements SampleDataDatabaseWriter
Writes sample data to the database and outputs whether the operation was successful.
Input/output:
- accepts:
adams.data.sampledata.SampleData[]
adams.data.spectrum.Spectrum[]
- generates:
java.lang.Boolean
-logging-level <OFF|SEVERE|WARNING|INFO|CONFIG|FINE|FINER|FINEST> (property: loggingLevel) The logging level for outputting errors and debugging output. default: WARNING
-name <java.lang.String> (property: name) The name of the actor. default: BulkSampleDataDbWriter
-annotation <adams.core.base.BaseAnnotation> (property: annotations) The annotations to attach to this actor. default:
-skip <boolean> (property: skip) If set to true, transformation is skipped and the input token is just forwarded as it is. default: false
-stop-flow-on-error <boolean> (property: stopFlowOnError) If set to true, the flow execution at this level gets stopped in case this actor encounters an error; the error gets propagated; useful for critical actors. default: false
-silent <boolean> (property: silent) If enabled, then no errors are output in the console; Note: the enclosing actor handler must have this enabled as well. default: false
-data-type <S|N|B|U> [-data-type ...] (property: dataTypes) The data types to import. default:
-skip-fields <boolean> (property: skipFields) If enabled, the supplied regular expression is used for identifying fields to skip (name + data type, e.g., 'blah[N]'). default: false
-skip-fields-regexp <adams.core.base.BaseRegExp> (property: skipFieldsRegExp) The regular expression for identifying fields to skip (if enabled). default: (Parent ID|Sample ID|Sample Type|Format|Insert Timestamp|Instrument|Source).* more: https://docs.oracle.com/javase/tutorial/essential/regex/ https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html
-batch-size <int> (property: batchSize) The batch size to use for the bulk operation. default: 1000 minimum: 1
-auto-commit <boolean> (property: autoCommit) If disabled, auto-commit gets turned off for the bulk update, which may impact other transactions; use with caution. default: true
-new-connection <boolean> (property: newConnection) If enabled, a new database connection is opened (and then closed) just for this operation; use this when turning off auto-commit. default: false
- Author:
- fracpete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description protected boolean
m_AutoCommit
whether to use auto-commit.protected int
m_BatchSize
the number of records in a batch.protected adams.data.report.DataType[]
m_DataTypes
the types of data to import.protected boolean
m_NewConnection
whether to use a new database connection.protected SampleDataF
m_SampleDataF
the instance that is currently running a bulk store.protected boolean
m_SkipFields
whether to skip fields.protected adams.core.base.BaseRegExp
m_SkipFieldsRegExp
the fields to ignore.-
Fields inherited from class adams.flow.transformer.AbstractTransformer
BACKUP_INPUT, BACKUP_OUTPUT, m_InputToken, m_OutputToken
-
Fields inherited from class adams.flow.core.AbstractActor
m_Annotations, m_BackupState, m_DetectedObjectVariables, m_DetectedVariables, m_ErrorHandler, m_Executed, m_Executing, m_ExecutionListeningSupporter, m_FullName, m_LoggingPrefix, m_Name, m_Parent, m_ScopeHandler, m_Self, m_Silent, m_Skip, m_StopFlowOnError, m_StopMessage, m_Stopped, m_StorageHandler, m_VariablesUpdated
-
-
Constructor Summary
Constructors Constructor Description BulkSampleDataDbWriter()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Class[]
accepts()
Returns the class that the consumer accepts.String
autoCommitTipText()
Returns the tip text for this property.String
batchSizeTipText()
Returns the tip text for this property.String
dataTypesTipText()
Returns the tip text for this property.void
defineOptions()
Adds options to the internal list of options.Class[]
generates()
Returns the class of objects that it generates.boolean
getAutoCommit()
Returns whether to use auto-commit for bulk transactions.int
getBatchSize()
Returns the batch size in use.protected adams.db.AbstractDatabaseConnection
getDatabaseConnection()
Determines the database connection in the flow.adams.data.report.DataType[]
getDataTypes()
Returns the data types to importprotected adams.db.AbstractDatabaseConnection
getDefaultDatabaseConnection()
Returns the default database connection.boolean
getNewConnection()
Returns whether to use a new connection for this update.String
getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.boolean
getSkipFields()
Returns whether to skip fields.adams.core.base.BaseRegExp
getSkipFieldsRegExp()
Returns the regular expression for identifying fields to skip (if enabled).String
globalInfo()
Returns a string describing the object.String
newConnectionTipText()
Returns the tip text for this property.protected String
queryDatabase()
Performs the actual database query.void
setAutoCommit(boolean value)
Sets whether to use auto-commit for bulk transaction.void
setBatchSize(int value)
Sets the batch size to use.void
setDataTypes(adams.data.report.DataType[] value)
Sets the data types to import.void
setNewConnection(boolean value)
Sets whether to use a new connection for this update.void
setSkipFields(boolean value)
Sets whether to skip fields.void
setSkipFieldsRegExp(adams.core.base.BaseRegExp value)
Sets the regular expression for identifying fields to skip (if enabled).String
skipFieldsRegExpTipText()
Returns the tip text for this property.String
skipFieldsTipText()
Returns the tip text for this property.void
stopExecution()
Stops the execution.void
wrapUp()
Cleans up after the execution has finished.-
Methods inherited from class adams.flow.transformer.AbstractDbTransformer
doExecute, initialize, setUpDatabaseConnection
-
Methods inherited from class adams.flow.transformer.AbstractTransformer
backupState, currentInput, execute, hasInput, hasPendingOutput, input, output, postExecute, restoreState
-
Methods inherited from class adams.flow.core.AbstractActor
annotationsTipText, canInspectOptions, canPerformSetUpCheck, cleanUp, compareTo, configureLogger, destroy, equals, finalUpdateVariables, findVariables, findVariables, forceVariables, forCommandLine, forName, forName, getAdditionalInformation, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowActors, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, handleException, hasErrorHandler, hasStopMessage, index, isBackedUp, isExecuted, isExecuting, isFinished, isHeadless, isStopped, nameTipText, performSetUpChecks, performVariableChecks, preExecute, pruneBackup, pruneBackup, reset, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setUp, setVariables, shallowCopy, shallowCopy, silentTipText, sizeOf, skipTipText, stopExecution, stopFlowOnErrorTipText, updateDetectedVariables, updatePrefix, updateVariables, variableChanged
-
Methods inherited from class adams.core.option.AbstractOptionHandler
cleanUpOptions, finishInit, getDefaultLoggingLevel, getOptionManager, loggingLevelTipText, newOptionManager, setLoggingLevel, toCommandLine, toString
-
Methods inherited from class adams.core.logging.LoggingObject
getLogger, getLoggingLevel, initializeLogging, isLoggingEnabled
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface adams.flow.core.Actor
cleanUp, compareTo, destroy, equals, execute, findVariables, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, hasErrorHandler, hasStopMessage, index, isExecuted, isFinished, isHeadless, isStopped, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setUp, setVariables, shallowCopy, shallowCopy, sizeOf, stopExecution, toCommandLine, variableChanged
-
-
-
-
Field Detail
-
m_DataTypes
protected adams.data.report.DataType[] m_DataTypes
the types of data to import.
-
m_SkipFields
protected boolean m_SkipFields
whether to skip fields.
-
m_SkipFieldsRegExp
protected adams.core.base.BaseRegExp m_SkipFieldsRegExp
the fields to ignore.
-
m_BatchSize
protected int m_BatchSize
the number of records in a batch.
-
m_AutoCommit
protected boolean m_AutoCommit
whether to use auto-commit.
-
m_NewConnection
protected boolean m_NewConnection
whether to use a new database connection.
-
m_SampleDataF
protected transient SampleDataF m_SampleDataF
the instance that is currently running a bulk store.
-
-
Method Detail
-
globalInfo
public String globalInfo()
Returns a string describing the object.- Specified by:
globalInfo
in interfaceadams.core.GlobalInfoSupporter
- Specified by:
globalInfo
in classadams.core.option.AbstractOptionHandler
- Returns:
- a description suitable for displaying in the gui
-
defineOptions
public void defineOptions()
Adds options to the internal list of options.- Specified by:
defineOptions
in interfaceadams.core.option.OptionHandler
- Overrides:
defineOptions
in classadams.flow.core.AbstractActor
-
setDataTypes
public void setDataTypes(adams.data.report.DataType[] value)
Sets the data types to import.- Parameters:
value
- the data types
-
getDataTypes
public adams.data.report.DataType[] getDataTypes()
Returns the data types to import- Returns:
- the data types
-
dataTypesTipText
public String dataTypesTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setSkipFields
public void setSkipFields(boolean value)
Sets whether to skip fields.- Parameters:
value
- true if to skip fields
-
getSkipFields
public boolean getSkipFields()
Returns whether to skip fields.- Returns:
- true if to skip fields
-
skipFieldsTipText
public String skipFieldsTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setSkipFieldsRegExp
public void setSkipFieldsRegExp(adams.core.base.BaseRegExp value)
Sets the regular expression for identifying fields to skip (if enabled).- Parameters:
value
- the expression
-
getSkipFieldsRegExp
public adams.core.base.BaseRegExp getSkipFieldsRegExp()
Returns the regular expression for identifying fields to skip (if enabled).- Returns:
- the expression
-
skipFieldsRegExpTipText
public String skipFieldsRegExpTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setBatchSize
public void setBatchSize(int value)
Sets the batch size to use.- Parameters:
value
- the size
-
getBatchSize
public int getBatchSize()
Returns the batch size in use.- Returns:
- the size
-
batchSizeTipText
public String batchSizeTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setAutoCommit
public void setAutoCommit(boolean value)
Sets whether to use auto-commit for bulk transaction. May impact other transactions, therefore use with caution!- Parameters:
value
- true if to use auto-commit
-
getAutoCommit
public boolean getAutoCommit()
Returns whether to use auto-commit for bulk transactions. May impact other transactions, therefore use with caution!- Returns:
- true if to use auto-commit
-
autoCommitTipText
public String autoCommitTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setNewConnection
public void setNewConnection(boolean value)
Sets whether to use a new connection for this update. Use when autoCommit is off.- Parameters:
value
- true if to use new connection
-
getNewConnection
public boolean getNewConnection()
Returns whether to use a new connection for this update. Use when autoCommit is off.- Returns:
- true if to use new connection
-
newConnectionTipText
public String newConnectionTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
getQuickInfo
public String getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.- Specified by:
getQuickInfo
in interfaceadams.flow.core.Actor
- Specified by:
getQuickInfo
in interfaceadams.core.QuickInfoSupporter
- Overrides:
getQuickInfo
in classadams.flow.core.AbstractActor
- Returns:
- null if no info available, otherwise short string
-
getDefaultDatabaseConnection
protected adams.db.AbstractDatabaseConnection getDefaultDatabaseConnection()
Returns the default database connection.- Specified by:
getDefaultDatabaseConnection
in classadams.flow.transformer.AbstractDbTransformer
- Returns:
- the default database connection
-
getDatabaseConnection
protected adams.db.AbstractDatabaseConnection getDatabaseConnection()
Determines the database connection in the flow.- Specified by:
getDatabaseConnection
in classadams.flow.transformer.AbstractDbTransformer
- Returns:
- the database connection to use
-
accepts
public Class[] accepts()
Returns the class that the consumer accepts.- Specified by:
accepts
in interfaceadams.flow.core.InputConsumer
- Returns:
- the report class
-
generates
public Class[] generates()
Returns the class of objects that it generates.- Specified by:
generates
in interfaceadams.flow.core.OutputProducer
- Returns:
- the Class of the generated tokens
-
queryDatabase
protected String queryDatabase()
Performs the actual database query.- Specified by:
queryDatabase
in classadams.flow.transformer.AbstractDbTransformer
- Returns:
- null if everything is fine, otherwise error message
-
stopExecution
public void stopExecution()
Stops the execution. No message set.- Specified by:
stopExecution
in interfaceadams.flow.core.Actor
- Specified by:
stopExecution
in interfaceadams.core.Stoppable
- Overrides:
stopExecution
in classadams.flow.core.AbstractActor
-
wrapUp
public void wrapUp()
Cleans up after the execution has finished. Graphical output is left untouched.- Specified by:
wrapUp
in interfaceadams.flow.core.Actor
- Overrides:
wrapUp
in classadams.flow.transformer.AbstractDbTransformer
-
-