Package org.h2.table
Class Table
- java.lang.Object
-
- org.h2.engine.DbObject
-
- org.h2.schema.SchemaObject
-
- org.h2.table.Table
-
- All Implemented Interfaces:
HasSQL
- Direct Known Subclasses:
MetaTable,TableBase,TableLink,TableView,VirtualTable
public abstract class Table extends SchemaObject
This is the base class for most tables. A table contains a list of columns and a list of rows.
-
-
Field Summary
Fields Modifier and Type Field Description private booleancheckForeignKeyConstraintsIs foreign key constraint checking enabled for this table.private java.util.HashMap<java.lang.String,Column>columnMapprotected Column[]columnsThe columns of this table.protected CompareModecompareModeThe compare mode used for this table.private java.util.ArrayList<Constraint>constraintsprivate java.util.concurrent.CopyOnWriteArrayList<TableView>dependentViewsviews that depend on this tablestatic intEXCLUSIVE_LOCKExclusive lock.protected booleanisHiddenProtected tables are not listed in the meta data and are excluded when using the SCRIPT command.private RownullRowprivate booleanonCommitDropprivate booleanonCommitTruncateprivate booleanpersistDataprivate booleanpersistIndexesstatic intREAD_LOCKRead lock.private RowFactoryrowFactoryprivate java.util.ArrayList<Sequence>sequencesprivate java.util.ArrayList<TableSynonym>synonymsprivate booleantableExpressionprivate java.util.ArrayList<TriggerObject>triggersstatic intTYPE_CACHEDThe table type that means this table is a regular persistent table.static intTYPE_MEMORYThe table type that means this table is a regular persistent table.static intWRITE_LOCKWrite lock.-
Fields inherited from class org.h2.engine.DbObject
AGGREGATE, comment, COMMENT, CONSTANT, CONSTRAINT, database, DOMAIN, FUNCTION_ALIAS, INDEX, RIGHT, ROLE, SCHEMA, SEQUENCE, SETTING, SYNONYM, TABLE_OR_VIEW, trace, TRIGGER, USER
-
Fields inherited from interface org.h2.util.HasSQL
ADD_PLAN_INFORMATION, DEFAULT_SQL_FLAGS, NO_CASTS, QUOTE_ONLY_WHEN_REQUIRED, REPLACE_LOBS_FOR_TRACE, TRACE_SQL_FLAGS
-
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description private static <T> java.util.ArrayList<T>add(java.util.ArrayList<T> list, T obj)voidaddConstraint(Constraint constraint)Add a constraint to the table.voidaddDependencies(java.util.HashSet<DbObject> dependencies)Add all objects that this table depends on to the hash set.voidaddDependentView(TableView view)Add a view to this table.abstract IndexaddIndex(SessionLocal session, java.lang.String indexName, int indexId, IndexColumn[] cols, int uniqueColumnCount, IndexType indexType, boolean create, java.lang.String indexComment)Create an index for this tableabstract voidaddRow(SessionLocal session, Row row)Add a row to the table and all indexes.voidaddSequence(Sequence sequence)Add a sequence to this table.voidaddSynonym(TableSynonym synonym)Add a synonym to this table.voidaddTrigger(TriggerObject trigger)Add a trigger to this table.abstract booleancanDrop()Check if this table can be dropped.abstract booleancanGetRowCount(SessionLocal session)Check if the row count can be retrieved quickly.booleancanReference()Check if this table can be referenced.booleancanTruncate()Check if this table can be truncated.java.util.ArrayList<SessionLocal>checkDeadlock(SessionLocal session, SessionLocal clash, java.util.Set<SessionLocal> visited)Check if a deadlock occurred.abstract voidcheckSupportAlter()Check if this table supports ALTER TABLE.voidcheckWritingAllowed()Tests if the table can be written.abstract voidclose(SessionLocal session)Close the table object and flush changes.intcompareValues(CastDataProvider provider, Value a, Value b)Compare two values with the current comparison mode.voidconvertInsertRow(SessionLocal session, Row row, java.lang.Boolean overridingSystem)Prepares the specified row for INSERT operation.voidconvertUpdateRow(SessionLocal session, Row row, boolean fromTrigger)Prepares the specified row for UPDATE operation.RowcreateRow(Value[] data, int memory)Create a new row for this table.booleandoesColumnExist(java.lang.String columnName)Does the column with the given name exist?voiddropMultipleColumnsConstraintsAndIndexes(SessionLocal session, java.util.ArrayList<Column> columnsToDrop)Check that these columns are not referenced by a multi-column constraint or multi-column index.ColumnfindColumn(java.lang.String columnName)Get the column with the given name if it exists.IndexfindPrimaryKey()Get the primary key index if there is one, or null if there is none.voidfire(SessionLocal session, int type, boolean beforeAction)Fire the triggers for this table.voidfireAfterRow(SessionLocal session, Row oldRow, Row newRow, boolean rollback)Fire all triggers that need to be called after a row is updated.booleanfireBeforeRow(SessionLocal session, Row oldRow, Row newRow)Fire all triggers that need to be called before a row is updated.private voidfireConstraints(SessionLocal session, Row oldRow, Row newRow, boolean before)booleanfireRow()Check if row based triggers or constraints are defined.private booleanfireRow(SessionLocal session, Row oldRow, Row newRow, boolean beforeAction, boolean rollback)PlanItemgetBestPlanItem(SessionLocal session, int[] masks, TableFilter[] filters, int filter, SortOrder sortOrder, AllColumnsForPlan allColumnsSet)Get the best plan for the given search mask.booleangetCheckForeignKeyConstraints()java.util.ArrayList<DbObject>getChildren()Get the list of dependent children (for tables, this includes indexes and so on).ColumngetColumn(int index)Get the column at the given index.ColumngetColumn(java.lang.String columnName)Get the column with the given name.ColumngetColumn(java.lang.String columnName, boolean ifExists)Get the column with the given name.Column[]getColumns()CompareModegetCompareMode()java.util.ArrayList<Constraint>getConstraints()java.lang.StringgetCreateSQLForCopy(Table table, java.lang.String quotedName)Build a SQL statement to re-create the object, or to create a copy of the object with a different name or referencing a different tablejava.util.concurrent.CopyOnWriteArrayList<TableView>getDependentViews()longgetDiskSpaceUsed()ColumngetIdentityColumn()Returns first identity column, ornull.IndexgetIndex(java.lang.String indexName)Get an index by name.abstract java.util.ArrayList<Index>getIndexes()Get all indexes for this table.IndexgetIndexForColumn(Column column, boolean needGetFirstOrLast, boolean needFindNext)Get the index that has the given column as the first element.private static IndexHintsgetIndexHints(TableFilter[] filters, int filter)intgetMainIndexColumn()Returns ID of main index column, orSearchRow.ROWID_INDEX.abstract longgetMaxDataModificationId()Get the last data modification id.RowgetNullRow()booleangetOnCommitDrop()booleangetOnCommitTruncate()IndexgetPrimaryKey()RowgetRow(SessionLocal session, long key)Get the given row.abstract longgetRowCount(SessionLocal session)Get the row count for this table.abstract longgetRowCountApproximation(SessionLocal session)Get the approximated row count for this table.RowFactorygetRowFactory()ColumngetRowIdColumn()Get the row id column if this table has one.abstract IndexgetScanIndex(SessionLocal session)Get the scan index to iterate through all rows.IndexgetScanIndex(SessionLocal session, int[] masks, TableFilter[] filters, int filter, SortOrder sortOrder, AllColumnsForPlan allColumnsSet)Get the scan index for this table.java.lang.StringgetSQLTableType()Return SQL table type for INFORMATION_SCHEMA.abstract TableTypegetTableType()Get the table type nameRowgetTemplateRow()SearchRowgetTemplateSimpleRow(boolean singleColumn)Get a new simple row object.java.util.ArrayList<TriggerObject>getTriggers()Return list of triggers.intgetType()Get the object type.booleanhasSelectTrigger()Check whether this table has a select trigger.abstract booleanisDeterministic()Check if the table is deterministic.booleanisGlobalTemporary()booleanisHidden()Check whether this is a hidden object that doesn't appear in the meta data and in the script, and is not dropped on DROP ALL OBJECTS.private static booleanisIndexExcludedByHints(IndexHints indexHints, Index index)booleanisInsertable()Returns whether this table is insertable.booleanisLockedExclusively()Check if this table is locked exclusively.booleanisLockedExclusivelyBy(SessionLocal session)Check if the table is exclusively locked by this session.booleanisPersistData()booleanisPersistIndexes()booleanisQueryComparable()Check whether the table (or view) contains no columns that prevent index conditions to be used.booleanisRowLockable()Views, function tables, links, etc.booleanisTableExpression()booleanisView()booleanlock(SessionLocal session, int lockType)Lock the table for the given session.RowlockRow(SessionLocal session, Row row)Locks row, preventing any updated to it, except from the session specified.private static voidremove(java.util.ArrayList<? extends DbObject> list, DbObject obj)voidremoveChildrenAndResources(SessionLocal session)Delete all dependent children objects and resources of this object.voidremoveColumnExpressionsDependencies(SessionLocal session)Removes dependencies of column expressions, used for tables with circular dependencies.voidremoveConstraint(Constraint constraint)Remove the given constraint from the list.voidremoveDependentView(TableView view)Remove the given view from the dependent views list.voidremoveIndex(Index index)Remove the given index from the list.voidremoveIndexOrTransferOwnership(SessionLocal session, Index index)If the index is still required by a constraint, transfer the ownership to it.abstract voidremoveRow(SessionLocal session, Row row)Remove a row from the table and all indexes.voidremoveSequence(Sequence sequence)Remove a sequence from the table.voidremoveSynonym(TableSynonym synonym)Remove the given view from the list.voidremoveTrigger(TriggerObject trigger)Remove the given trigger from the list.voidrename(java.lang.String newName)Rename the object.voidrenameColumn(Column column, java.lang.String newName)Rename a column of this table.voidsetCheckForeignKeyConstraints(SessionLocal session, boolean enabled, boolean checkExisting)Enable or disable foreign key constraint checking for this table.protected voidsetColumns(Column[] columns)voidsetHidden(boolean hidden)voidsetOnCommitDrop(boolean onCommitDrop)voidsetOnCommitTruncate(boolean onCommitTruncate)voidsetTableExpression(boolean tableExpression)abstract longtruncate(SessionLocal session)Remove all rows from the table and indexes.voidunlock(SessionLocal s)Release the lock for this session.voidupdateRow(SessionLocal session, Row oldRow, Row newRow)Update a row to the table and all indexes.voidupdateRows(Prepared prepared, SessionLocal session, LocalResult rows)Update a list of rows in this table.-
Methods inherited from class org.h2.schema.SchemaObject
getSchema, getSQL, getSQL
-
Methods inherited from class org.h2.engine.DbObject
checkRename, getComment, getCreateSQL, getCreateSQLForMeta, getDatabase, getDropSQL, getId, getModificationId, getName, invalidate, isTemporary, isValid, setComment, setModified, setObjectName, setTemporary, toString
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.h2.util.HasSQL
getTraceSQL
-
-
-
-
Field Detail
-
TYPE_CACHED
public static final int TYPE_CACHED
The table type that means this table is a regular persistent table.- See Also:
- Constant Field Values
-
TYPE_MEMORY
public static final int TYPE_MEMORY
The table type that means this table is a regular persistent table.- See Also:
- Constant Field Values
-
READ_LOCK
public static final int READ_LOCK
Read lock.- See Also:
- Constant Field Values
-
WRITE_LOCK
public static final int WRITE_LOCK
Write lock.- See Also:
- Constant Field Values
-
EXCLUSIVE_LOCK
public static final int EXCLUSIVE_LOCK
Exclusive lock.- See Also:
- Constant Field Values
-
columns
protected Column[] columns
The columns of this table.
-
compareMode
protected CompareMode compareMode
The compare mode used for this table.
-
isHidden
protected boolean isHidden
Protected tables are not listed in the meta data and are excluded when using the SCRIPT command.
-
columnMap
private final java.util.HashMap<java.lang.String,Column> columnMap
-
persistIndexes
private final boolean persistIndexes
-
persistData
private final boolean persistData
-
triggers
private java.util.ArrayList<TriggerObject> triggers
-
constraints
private java.util.ArrayList<Constraint> constraints
-
sequences
private java.util.ArrayList<Sequence> sequences
-
dependentViews
private final java.util.concurrent.CopyOnWriteArrayList<TableView> dependentViews
views that depend on this table
-
synonyms
private java.util.ArrayList<TableSynonym> synonyms
-
checkForeignKeyConstraints
private boolean checkForeignKeyConstraints
Is foreign key constraint checking enabled for this table.
-
onCommitDrop
private boolean onCommitDrop
-
onCommitTruncate
private boolean onCommitTruncate
-
nullRow
private volatile Row nullRow
-
rowFactory
private RowFactory rowFactory
-
tableExpression
private boolean tableExpression
-
-
Constructor Detail
-
Table
protected Table(Schema schema, int id, java.lang.String name, boolean persistIndexes, boolean persistData)
-
-
Method Detail
-
rename
public void rename(java.lang.String newName)
Description copied from class:DbObjectRename the object.
-
isView
public boolean isView()
-
lock
public boolean lock(SessionLocal session, int lockType)
Lock the table for the given session. This method waits until the lock is granted.- Parameters:
session- the sessionlockType- the type of lock- Returns:
- true if the table was already exclusively locked by this session.
- Throws:
DbException- if a lock timeout occurred
-
close
public abstract void close(SessionLocal session)
Close the table object and flush changes.- Parameters:
session- the session
-
unlock
public void unlock(SessionLocal s)
Release the lock for this session.- Parameters:
s- the session
-
addIndex
public abstract Index addIndex(SessionLocal session, java.lang.String indexName, int indexId, IndexColumn[] cols, int uniqueColumnCount, IndexType indexType, boolean create, java.lang.String indexComment)
Create an index for this table- Parameters:
session- the sessionindexName- the name of the indexindexId- the idcols- the index columnsuniqueColumnCount- the count of unique columnsindexType- the index typecreate- whether this is a new indexindexComment- the comment- Returns:
- the index
-
getRow
public Row getRow(SessionLocal session, long key)
Get the given row.- Parameters:
session- the sessionkey- the primary key- Returns:
- the row
-
isInsertable
public boolean isInsertable()
Returns whether this table is insertable.- Returns:
- whether this table is insertable
-
removeRow
public abstract void removeRow(SessionLocal session, Row row)
Remove a row from the table and all indexes.- Parameters:
session- the sessionrow- the row
-
lockRow
public Row lockRow(SessionLocal session, Row row)
Locks row, preventing any updated to it, except from the session specified.- Parameters:
session- the sessionrow- to lock- Returns:
- locked row, or null if row does not exist anymore
-
truncate
public abstract long truncate(SessionLocal session)
Remove all rows from the table and indexes.- Parameters:
session- the session- Returns:
- number of removed rows, possibly including uncommitted rows
-
addRow
public abstract void addRow(SessionLocal session, Row row)
Add a row to the table and all indexes.- Parameters:
session- the sessionrow- the row- Throws:
DbException- if a constraint was violated
-
updateRow
public void updateRow(SessionLocal session, Row oldRow, Row newRow)
Update a row to the table and all indexes.- Parameters:
session- the sessionoldRow- the row to updatenewRow- the row with updated values (_rowid_ suppose to be the same)- Throws:
DbException- if a constraint was violated
-
checkSupportAlter
public abstract void checkSupportAlter()
Check if this table supports ALTER TABLE.- Throws:
DbException- if it is not supported
-
getTableType
public abstract TableType getTableType()
Get the table type name- Returns:
- the table type name
-
getSQLTableType
public java.lang.String getSQLTableType()
Return SQL table type for INFORMATION_SCHEMA.- Returns:
- SQL table type for INFORMATION_SCHEMA
-
getScanIndex
public abstract Index getScanIndex(SessionLocal session)
Get the scan index to iterate through all rows.- Parameters:
session- the session- Returns:
- the index
-
getScanIndex
public Index getScanIndex(SessionLocal session, int[] masks, TableFilter[] filters, int filter, SortOrder sortOrder, AllColumnsForPlan allColumnsSet)
Get the scan index for this table.- Parameters:
session- the sessionmasks- the search maskfilters- the table filtersfilter- the filter indexsortOrder- the sort orderallColumnsSet- all columns- Returns:
- the scan index
-
getIndexes
public abstract java.util.ArrayList<Index> getIndexes()
Get all indexes for this table.- Returns:
- the list of indexes
-
getIndex
public Index getIndex(java.lang.String indexName)
Get an index by name.- Parameters:
indexName- the index name to search for- Returns:
- the found index
-
isLockedExclusively
public boolean isLockedExclusively()
Check if this table is locked exclusively.- Returns:
- true if it is.
-
getMaxDataModificationId
public abstract long getMaxDataModificationId()
Get the last data modification id.- Returns:
- the modification id
-
isDeterministic
public abstract boolean isDeterministic()
Check if the table is deterministic.- Returns:
- true if it is
-
canGetRowCount
public abstract boolean canGetRowCount(SessionLocal session)
Check if the row count can be retrieved quickly.- Parameters:
session- the session- Returns:
- true if it can
-
canReference
public boolean canReference()
Check if this table can be referenced.- Returns:
- true if it can
-
canDrop
public abstract boolean canDrop()
Check if this table can be dropped.- Returns:
- true if it can
-
getRowCount
public abstract long getRowCount(SessionLocal session)
Get the row count for this table.- Parameters:
session- the session- Returns:
- the row count
-
getRowCountApproximation
public abstract long getRowCountApproximation(SessionLocal session)
Get the approximated row count for this table.- Parameters:
session- the session- Returns:
- the approximated row count
-
getDiskSpaceUsed
public long getDiskSpaceUsed()
-
getRowIdColumn
public Column getRowIdColumn()
Get the row id column if this table has one.- Returns:
- the row id column, or null
-
getCreateSQLForCopy
public java.lang.String getCreateSQLForCopy(Table table, java.lang.String quotedName)
Description copied from class:DbObjectBuild a SQL statement to re-create the object, or to create a copy of the object with a different name or referencing a different table- Specified by:
getCreateSQLForCopyin classDbObject- Parameters:
table- the new tablequotedName- the quoted name- Returns:
- the SQL statement
-
isQueryComparable
public boolean isQueryComparable()
Check whether the table (or view) contains no columns that prevent index conditions to be used. For example, a view that contains the ROWNUM() pseudo-column prevents this.- Returns:
- true if the table contains no query-comparable column
-
addDependencies
public void addDependencies(java.util.HashSet<DbObject> dependencies)
Add all objects that this table depends on to the hash set.- Parameters:
dependencies- the current set of dependencies
-
getChildren
public java.util.ArrayList<DbObject> getChildren()
Description copied from class:DbObjectGet the list of dependent children (for tables, this includes indexes and so on).- Overrides:
getChildrenin classDbObject- Returns:
- the list of children, or
null
-
setColumns
protected void setColumns(Column[] columns)
-
renameColumn
public void renameColumn(Column column, java.lang.String newName)
Rename a column of this table.- Parameters:
column- the column to renamenewName- the new column name
-
isLockedExclusivelyBy
public boolean isLockedExclusivelyBy(SessionLocal session)
Check if the table is exclusively locked by this session.- Parameters:
session- the session- Returns:
- true if it is
-
updateRows
public void updateRows(Prepared prepared, SessionLocal session, LocalResult rows)
Update a list of rows in this table.- Parameters:
prepared- the prepared statementsession- the sessionrows- a list of row pairs of the form old row, new row, old row, new row,...
-
getDependentViews
public java.util.concurrent.CopyOnWriteArrayList<TableView> getDependentViews()
-
removeChildrenAndResources
public void removeChildrenAndResources(SessionLocal session)
Description copied from class:DbObjectDelete all dependent children objects and resources of this object.- Specified by:
removeChildrenAndResourcesin classDbObject- Parameters:
session- the session
-
dropMultipleColumnsConstraintsAndIndexes
public void dropMultipleColumnsConstraintsAndIndexes(SessionLocal session, java.util.ArrayList<Column> columnsToDrop)
Check that these columns are not referenced by a multi-column constraint or multi-column index. If it is, an exception is thrown. Single-column references and indexes are dropped.- Parameters:
session- the sessioncolumnsToDrop- the columns to drop- Throws:
DbException- if the column is referenced by multi-column constraints or indexes
-
getRowFactory
public RowFactory getRowFactory()
-
createRow
public Row createRow(Value[] data, int memory)
Create a new row for this table.- Parameters:
data- the valuesmemory- the estimated memory usage in bytes- Returns:
- the created row
-
getTemplateRow
public Row getTemplateRow()
-
getTemplateSimpleRow
public SearchRow getTemplateSimpleRow(boolean singleColumn)
Get a new simple row object.- Parameters:
singleColumn- if only one value need to be stored- Returns:
- the simple row object
-
getNullRow
public Row getNullRow()
-
getColumns
public Column[] getColumns()
-
getType
public int getType()
Description copied from class:DbObjectGet the object type.
-
getColumn
public Column getColumn(int index)
Get the column at the given index.- Parameters:
index- the column index (0, 1,...)- Returns:
- the column
-
getColumn
public Column getColumn(java.lang.String columnName)
Get the column with the given name.- Parameters:
columnName- the column name- Returns:
- the column
- Throws:
DbException- if the column was not found
-
getColumn
public Column getColumn(java.lang.String columnName, boolean ifExists)
Get the column with the given name.- Parameters:
columnName- the column nameifExists- if (@code true) returnnullif column does not exist- Returns:
- the column
- Throws:
DbException- if the column was not found
-
findColumn
public Column findColumn(java.lang.String columnName)
Get the column with the given name if it exists.- Parameters:
columnName- the column name, ornull- Returns:
- the column
-
doesColumnExist
public boolean doesColumnExist(java.lang.String columnName)
Does the column with the given name exist?- Parameters:
columnName- the column name- Returns:
- true if the column exists
-
getIdentityColumn
public Column getIdentityColumn()
Returns first identity column, ornull.- Returns:
- first identity column, or
null
-
getBestPlanItem
public PlanItem getBestPlanItem(SessionLocal session, int[] masks, TableFilter[] filters, int filter, SortOrder sortOrder, AllColumnsForPlan allColumnsSet)
Get the best plan for the given search mask.- Parameters:
session- the sessionmasks- per-column comparison bit masks, null means 'always false', see constants in IndexConditionfilters- all joined table filtersfilter- the current table filter indexsortOrder- the sort orderallColumnsSet- the set of all columns- Returns:
- the plan item
-
isIndexExcludedByHints
private static boolean isIndexExcludedByHints(IndexHints indexHints, Index index)
-
getIndexHints
private static IndexHints getIndexHints(TableFilter[] filters, int filter)
-
findPrimaryKey
public Index findPrimaryKey()
Get the primary key index if there is one, or null if there is none.- Returns:
- the primary key index or null
-
getPrimaryKey
public Index getPrimaryKey()
-
convertInsertRow
public void convertInsertRow(SessionLocal session, Row row, java.lang.Boolean overridingSystem)
Prepares the specified row for INSERT operation. Identity, default, and generated values are evaluated, all values are converted to target data types and validated. Base value of identity column is updated when required by compatibility mode.- Parameters:
session- the sessionoverridingSystem-Boolean.TRUEforOVERRIDING SYSTEM VALUES,Boolean.FALSEforOVERRIDING USER VALUES,nullif override clause is not specifiedrow- the row
-
convertUpdateRow
public void convertUpdateRow(SessionLocal session, Row row, boolean fromTrigger)
Prepares the specified row for UPDATE operation. Default and generated values are evaluated, all values are converted to target data types and validated. Base value of identity column is updated when required by compatibility mode.- Parameters:
session- the sessionrow- the rowfromTrigger-trueif row was modified by INSERT or UPDATE trigger
-
removeIndex
public void removeIndex(Index index)
Remove the given index from the list.- Parameters:
index- the index to remove
-
removeDependentView
public void removeDependentView(TableView view)
Remove the given view from the dependent views list.- Parameters:
view- the view to remove
-
removeSynonym
public void removeSynonym(TableSynonym synonym)
Remove the given view from the list.- Parameters:
synonym- the synonym to remove
-
removeConstraint
public void removeConstraint(Constraint constraint)
Remove the given constraint from the list.- Parameters:
constraint- the constraint to remove
-
removeSequence
public final void removeSequence(Sequence sequence)
Remove a sequence from the table. Sequences are used as identity columns.- Parameters:
sequence- the sequence to remove
-
removeTrigger
public void removeTrigger(TriggerObject trigger)
Remove the given trigger from the list.- Parameters:
trigger- the trigger to remove
-
addDependentView
public void addDependentView(TableView view)
Add a view to this table.- Parameters:
view- the view to add
-
addSynonym
public void addSynonym(TableSynonym synonym)
Add a synonym to this table.- Parameters:
synonym- the synonym to add
-
addConstraint
public void addConstraint(Constraint constraint)
Add a constraint to the table.- Parameters:
constraint- the constraint to add
-
getConstraints
public java.util.ArrayList<Constraint> getConstraints()
-
addSequence
public void addSequence(Sequence sequence)
Add a sequence to this table.- Parameters:
sequence- the sequence to add
-
addTrigger
public void addTrigger(TriggerObject trigger)
Add a trigger to this table.- Parameters:
trigger- the trigger to add
-
add
private static <T> java.util.ArrayList<T> add(java.util.ArrayList<T> list, T obj)
-
fire
public void fire(SessionLocal session, int type, boolean beforeAction)
Fire the triggers for this table.- Parameters:
session- the sessiontype- the trigger typebeforeAction- whether 'before' triggers should be called
-
hasSelectTrigger
public boolean hasSelectTrigger()
Check whether this table has a select trigger.- Returns:
- true if it has
-
fireRow
public boolean fireRow()
Check if row based triggers or constraints are defined. In this case the fire after and before row methods need to be called.- Returns:
- if there are any triggers or rows defined
-
fireBeforeRow
public boolean fireBeforeRow(SessionLocal session, Row oldRow, Row newRow)
Fire all triggers that need to be called before a row is updated.- Parameters:
session- the sessionoldRow- the old data or null for an insertnewRow- the new data or null for a delete- Returns:
- true if no further action is required (for 'instead of' triggers)
-
fireConstraints
private void fireConstraints(SessionLocal session, Row oldRow, Row newRow, boolean before)
-
fireAfterRow
public void fireAfterRow(SessionLocal session, Row oldRow, Row newRow, boolean rollback)
Fire all triggers that need to be called after a row is updated.- Parameters:
session- the sessionoldRow- the old data or null for an insertnewRow- the new data or null for a deleterollback- when the operation occurred within a rollback
-
fireRow
private boolean fireRow(SessionLocal session, Row oldRow, Row newRow, boolean beforeAction, boolean rollback)
-
isGlobalTemporary
public boolean isGlobalTemporary()
-
canTruncate
public boolean canTruncate()
Check if this table can be truncated.- Returns:
- true if it can
-
setCheckForeignKeyConstraints
public void setCheckForeignKeyConstraints(SessionLocal session, boolean enabled, boolean checkExisting)
Enable or disable foreign key constraint checking for this table.- Parameters:
session- the sessionenabled- true if checking should be enabledcheckExisting- true if existing rows must be checked during this call
-
getCheckForeignKeyConstraints
public boolean getCheckForeignKeyConstraints()
- Returns:
- is foreign key constraint checking enabled for this table.
-
getIndexForColumn
public Index getIndexForColumn(Column column, boolean needGetFirstOrLast, boolean needFindNext)
Get the index that has the given column as the first element. This method returns null if no matching index is found.- Parameters:
column- the columnneedGetFirstOrLast- if the returned index must be able to doIndex.canGetFirstOrLast()needFindNext- if the returned index must be able to doIndex.findNext(SessionLocal, SearchRow, SearchRow)- Returns:
- the index or null
-
getOnCommitDrop
public boolean getOnCommitDrop()
-
setOnCommitDrop
public void setOnCommitDrop(boolean onCommitDrop)
-
getOnCommitTruncate
public boolean getOnCommitTruncate()
-
setOnCommitTruncate
public void setOnCommitTruncate(boolean onCommitTruncate)
-
removeIndexOrTransferOwnership
public void removeIndexOrTransferOwnership(SessionLocal session, Index index)
If the index is still required by a constraint, transfer the ownership to it. Otherwise, the index is removed.- Parameters:
session- the sessionindex- the index that is no longer required
-
removeColumnExpressionsDependencies
public void removeColumnExpressionsDependencies(SessionLocal session)
Removes dependencies of column expressions, used for tables with circular dependencies.- Parameters:
session- the session
-
checkDeadlock
public java.util.ArrayList<SessionLocal> checkDeadlock(SessionLocal session, SessionLocal clash, java.util.Set<SessionLocal> visited)
Check if a deadlock occurred. This method is called recursively. There is a circle if the session to be tested has already being visited. If this session is part of the circle (if it is the clash session), the method must return an empty object array. Once a deadlock has been detected, the methods must add the session to the list. If this session is not part of the circle, or if no deadlock is detected, this method returns null.- Parameters:
session- the session to be tested forclash- set with sessions already visited, and null when starting verificationvisited- set with sessions already visited, and null when starting verification- Returns:
- an object array with the sessions involved in the deadlock, or null
-
isPersistIndexes
public boolean isPersistIndexes()
-
isPersistData
public boolean isPersistData()
-
compareValues
public int compareValues(CastDataProvider provider, Value a, Value b)
Compare two values with the current comparison mode. The values may be of different type.- Parameters:
provider- the cast information providera- the first valueb- the second value- Returns:
- 0 if both values are equal, -1 if the first value is smaller, and 1 otherwise
-
getCompareMode
public CompareMode getCompareMode()
-
checkWritingAllowed
public void checkWritingAllowed()
Tests if the table can be written. Usually, this depends on the database.checkWritingAllowed method, but some tables (eg. TableLink) overwrite this default behaviour.
-
isHidden
public boolean isHidden()
Description copied from class:SchemaObjectCheck whether this is a hidden object that doesn't appear in the meta data and in the script, and is not dropped on DROP ALL OBJECTS.- Overrides:
isHiddenin classSchemaObject- Returns:
- true if it is hidden
-
setHidden
public void setHidden(boolean hidden)
-
isRowLockable
public boolean isRowLockable()
Views, function tables, links, etc. do not support locks- Returns:
- true if table supports row-level locks
-
setTableExpression
public void setTableExpression(boolean tableExpression)
-
isTableExpression
public boolean isTableExpression()
-
getTriggers
public java.util.ArrayList<TriggerObject> getTriggers()
Return list of triggers.- Returns:
- list of triggers
-
getMainIndexColumn
public int getMainIndexColumn()
Returns ID of main index column, orSearchRow.ROWID_INDEX.- Returns:
- ID of main index column, or
SearchRow.ROWID_INDEX
-
-