org.apache.derby.impl.sql.conn
Class GenericStatementContext

java.lang.Object
  extended byorg.apache.derby.iapi.services.context.ContextImpl
      extended byorg.apache.derby.impl.sql.conn.GenericStatementContext
All Implemented Interfaces:
Context, StatementContext

final class GenericStatementContext
extends ContextImpl
implements StatementContext

GenericStatementContext is pushed/popped around a statement prepare and execute so that any statement specific clean up can be performed.

Author:
jerry

Field Summary
private  java.util.ArrayList dependencies
           
private  java.lang.String internalSavePointName
           
private  boolean inUse
           
private  boolean isAtomic
           
private  boolean isSystemCode
           
private  LanguageConnectionContext lcc
           
private  NoPutResultSet[] materializedSubqueries
           
private  boolean parentInTrigger
           
private  ParameterValueSet pvs
           
private  boolean rollbackParentContext
           
private  boolean setSavePoint
           
private  short sqlAllowed
          Set to one of RoutineAliasInfo.
private  java.lang.String stmtText
           
private  NoPutResultSet[] subqueryTrackingArray
           
private  TransactionController tc
           
private  ResultSet topResultSet
           
 
Fields inherited from class org.apache.derby.iapi.services.context.ContextImpl
 
Constructor Summary
(package private) GenericStatementContext(LanguageConnectionContext lcc, TransactionController tc)
           
 
Method Summary
 void addDependency(Dependency dy)
          Track a Dependency within this StatementContext.
 java.lang.StringBuffer appendErrorInfo()
           
 void cleanupOnError(java.lang.Throwable error)
          Close down the top ResultSet, if relevant, and rollback to the internal savepoint, if one was set.
 void clearInUse()
          Mark this context as not in use.
 void clearSavePoint()
          Clear the save point for the current statement.
 short getSQLAllowed()
          Get the setting of the SQL allowed state.
 java.lang.String getStatementText()
          Return the text of the current statement.
 NoPutResultSet[] getSubqueryTrackingArray()
          Get the subquery tracking array for this query.
 boolean getSystemCode()
          Return true if this statement is system code.
 boolean inTrigger()
          Returns whether we started from within the context of a trigger or not.
 boolean inUse()
          Is this statement context in use or not.
 boolean isAtomic()
          Indicates whether the statement needs to be executed atomically or not, i.e., whether a commit/rollback is permitted by a connection nested in this statement.
 boolean isLastHandler(int severity)
          Return whether or not this context is the "last" handler for a the specified severity level.
 boolean onStack()
          Reports whether this StatementContext is on the context stack.
private  void pleaseBeOnStack()
          Raise an exception if this Context is not in use, that is, on the Context Stack.
 void resetSavePoint()
          Resets the savepoint to the current spot if it is set, otherwise, noop.
 void setInUse(boolean parentInTrigger, boolean isAtomic, java.lang.String stmtText, ParameterValueSet pvs)
          Mark this context as being in use.
 void setParentRollback()
          Indicate that, in the event of a statement-level exception, this context is NOT the last one that needs to be rolled back--rather, it is nested within some other statement context, and that other context needs to be rolled back, too.
 void setSavePoint()
          Set a save point for the current statement.
 void setSQLAllowed(short allow, boolean force)
          Set the level of SQL allowed in this and subsequent nested statements due to a routine call.
 void setSubqueryResultSet(int subqueryNumber, NoPutResultSet subqueryResultSet, int numSubqueries)
          Set the appropriate entry in the subquery tracking array for the specified subquery.
 void setSystemCode()
          Set to indicate statement is system code.
 void setTopResultSet(ResultSet topResultSet, NoPutResultSet[] subqueryTrackingArray)
          Set the top ResultSet in the ResultSet tree for close down on an error.
private  void stuffTopResultSet(ResultSet topResultSet, NoPutResultSet[] subqueryTrackingArray)
          Private minion of setTopResultSet() and clearInUse()
 
Methods inherited from class org.apache.derby.iapi.services.context.ContextImpl
getContextManager, getIdName, popMe, pushMe
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface org.apache.derby.iapi.services.context.Context
getContextManager, getIdName, popMe, pushMe
 

Field Detail

tc

private final TransactionController tc

setSavePoint

private boolean setSavePoint

internalSavePointName

private java.lang.String internalSavePointName

topResultSet

private ResultSet topResultSet

dependencies

private java.util.ArrayList dependencies

subqueryTrackingArray

private NoPutResultSet[] subqueryTrackingArray

materializedSubqueries

private NoPutResultSet[] materializedSubqueries

lcc

private final LanguageConnectionContext lcc

inUse

private boolean inUse

parentInTrigger

private boolean parentInTrigger

isAtomic

private boolean isAtomic

isSystemCode

private boolean isSystemCode

rollbackParentContext

private boolean rollbackParentContext

stmtText

private java.lang.String stmtText

pvs

private ParameterValueSet pvs

sqlAllowed

private short sqlAllowed
Set to one of RoutineAliasInfo.{MODIFIES_SQL_DATA, READS_SQL_DATA, CONTAINS_SQL, NO_SQL}

Constructor Detail

GenericStatementContext

GenericStatementContext(LanguageConnectionContext lcc,
                        TransactionController tc)
Method Detail

setInUse

public void setInUse(boolean parentInTrigger,
                     boolean isAtomic,
                     java.lang.String stmtText,
                     ParameterValueSet pvs)
Description copied from interface: StatementContext
Mark this context as being in use.

Specified by:
setInUse in interface StatementContext
Parameters:
isAtomic - true if the statement must be executed atomically
stmtText - the text of the statement. Needed for any language statement (currently, for any statement that can cause a trigger to fire). Please set this unless you are some funky jdbc setXXX method or something.
pvs - parameter value set, if it has one

clearInUse

public void clearInUse()
Description copied from interface: StatementContext
Mark this context as not in use. This is important because we always leave the top statement context on the stack, and we don't want to clean it up if a statement level exception happens while the context is not in use.

Specified by:
clearInUse in interface StatementContext

setSavePoint

public void setSavePoint()
                  throws StandardException
Description copied from interface: StatementContext
Set a save point for the current statement. NOTE: This needs to be off of the StatementContext so that it gets cleared on a statement error.

Specified by:
setSavePoint in interface StatementContext
Throws:
StandardException - Thrown on error
See Also:
StatementContext.setSavePoint()

resetSavePoint

public void resetSavePoint()
                    throws StandardException
Resets the savepoint to the current spot if it is set, otherwise, noop. Used when a commit is done on a nested connection.

Specified by:
resetSavePoint in interface StatementContext
Throws:
StandardException - Thrown on error
See Also:
StatementContext.resetSavePoint()

clearSavePoint

public void clearSavePoint()
                    throws StandardException
Description copied from interface: StatementContext
Clear the save point for the current statement.

Specified by:
clearSavePoint in interface StatementContext
Throws:
StandardException - Thrown on error
See Also:
StatementContext.clearSavePoint()

setTopResultSet

public void setTopResultSet(ResultSet topResultSet,
                            NoPutResultSet[] subqueryTrackingArray)
                     throws StandardException
Set the top ResultSet in the ResultSet tree for close down on an error.

Specified by:
setTopResultSet in interface StatementContext
Parameters:
topResultSet - The top ResultSet in the ResultSet tree
subqueryTrackingArray - (Sparse) of tops of subquery ResultSet trees
Returns:
Nothing.
Throws:
StandardException - thrown on error.

stuffTopResultSet

private void stuffTopResultSet(ResultSet topResultSet,
                               NoPutResultSet[] subqueryTrackingArray)
Private minion of setTopResultSet() and clearInUse()

Parameters:
topResultSet - make this the top result set
subqueryTrackingArray - where to keep track of subqueries in this statement
Returns:
Nothing.

setSubqueryResultSet

public void setSubqueryResultSet(int subqueryNumber,
                                 NoPutResultSet subqueryResultSet,
                                 int numSubqueries)
                          throws StandardException
Set the appropriate entry in the subquery tracking array for the specified subquery. Useful for closing down open subqueries on an exception.

Specified by:
setSubqueryResultSet in interface StatementContext
Parameters:
subqueryNumber - The subquery # for this subquery
subqueryResultSet - The ResultSet at the top of the subquery
numSubqueries - The total # of subqueries in the entire query
Returns:
Nothing.
Throws:
StandardException - thrown on error.

getSubqueryTrackingArray

public NoPutResultSet[] getSubqueryTrackingArray()
                                          throws StandardException
Get the subquery tracking array for this query. (Useful for runtime statistics.)

Specified by:
getSubqueryTrackingArray in interface StatementContext
Returns:
NoPutResultSet[] The (sparse) array of tops of subquery ResultSet trees
Throws:
StandardException - thrown on error.

addDependency

public void addDependency(Dependency dy)
                   throws StandardException
Track a Dependency within this StatementContext. (We need to clear any dependencies added within this context on an error.

Specified by:
addDependency in interface StatementContext
Parameters:
dy - The dependency to track.
Returns:
Nothing.
Throws:
StandardException - thrown on error.

inTrigger

public boolean inTrigger()
Returns whether we started from within the context of a trigger or not.

Specified by:
inTrigger in interface StatementContext
Returns:
true if we are in a trigger context

cleanupOnError

public void cleanupOnError(java.lang.Throwable error)
                    throws StandardException
Close down the top ResultSet, if relevant, and rollback to the internal savepoint, if one was set.

Specified by:
cleanupOnError in interface Context
Throws:
StandardException - thrown on error. REVISIT: don't want cleanupOnError's to throw exceptions.

isLastHandler

public boolean isLastHandler(int severity)
Description copied from interface: Context
Return whether or not this context is the "last" handler for a the specified severity level. Previously, the context manager would march through all of the contexts in cleanupOnError() and call each of their cleanupOnError() methods. That did not work with server side JDBC, especially for a StatementException, because outer contexts could get cleaned up incorrectly. This functionality is specific to the Language system. Any non-language system contexts should return ExceptionSeverity.NOT_APPLICABLE_SEVERITY. NOTE: Both the LanguageConnectionContext and the JDBC Connection Context are interested in session level errors because they both have clean up to do. This method allows both of them to return false so that all such handlers under them can do their clean up.

Specified by:
isLastHandler in interface Context
Overrides:
isLastHandler in class ContextImpl
See Also:
Context.isLastHandler(int)

onStack

public boolean onStack()
Reports whether this StatementContext is on the context stack.

Specified by:
onStack in interface StatementContext
Returns:
true if this StatementContext is on the context stack. false otherwise.

isAtomic

public boolean isAtomic()
Indicates whether the statement needs to be executed atomically or not, i.e., whether a commit/rollback is permitted by a connection nested in this statement.

Specified by:
isAtomic in interface StatementContext
Returns:
true if needs to be atomic

getStatementText

public java.lang.String getStatementText()
Return the text of the current statement. Note that this may be null. It is currently not set up correctly for ResultSets that aren't single row result sets (e.g SELECT), replication, and setXXXX/getXXXX jdbc methods.

Specified by:
getStatementText in interface StatementContext
Returns:
the statement text

pleaseBeOnStack

private void pleaseBeOnStack()
                      throws StandardException
Raise an exception if this Context is not in use, that is, on the Context Stack.

Throws:
StandardException - thrown on error.

inUse

public boolean inUse()
Description copied from interface: StatementContext
Is this statement context in use or not.

Specified by:
inUse in interface StatementContext
Returns:
true if in use

setSQLAllowed

public void setSQLAllowed(short allow,
                          boolean force)
Description copied from interface: StatementContext
Set the level of SQL allowed in this and subsequent nested statements due to a routine call. Value must be one of RoutineAliasInfo.{MODIFIES_SQL_DATA, READS_SQL_DATA, CONTAINS_SQL, NO_SQL}

Specified by:
setSQLAllowed in interface StatementContext
Parameters:
force - set to true to override more restrictive setting. Used to reset the permissions after a function call.

getSQLAllowed

public short getSQLAllowed()
Description copied from interface: StatementContext
Get the setting of the SQL allowed state.

Specified by:
getSQLAllowed in interface StatementContext

setParentRollback

public void setParentRollback()
Indicate that, in the event of a statement-level exception, this context is NOT the last one that needs to be rolled back--rather, it is nested within some other statement context, and that other context needs to be rolled back, too.

Specified by:
setParentRollback in interface StatementContext

setSystemCode

public void setSystemCode()
Set to indicate statement is system code. For example a system procedure, view, function etc.

Specified by:
setSystemCode in interface StatementContext

getSystemCode

public boolean getSystemCode()
Return true if this statement is system code.

Specified by:
getSystemCode in interface StatementContext

appendErrorInfo

public java.lang.StringBuffer appendErrorInfo()
Overrides:
appendErrorInfo in class ContextImpl

Built on Mon 2007-06-04 09:58:47+0400, from revision ???

Apache Derby V10.1 Engine Documentation - Copyright © 1997,2005 The Apache Software Foundation or its licensors, as applicable.