Package org.h2.command
Class Prepared
java.lang.Object
org.h2.command.Prepared
- Direct Known Subclasses:
BackupCommand,Call,DataChangeStatement,DefineCommand,ExecuteImmediate,ExecuteProcedure,Explain,Help,NoOperation,Query,RunScriptCommand,ScriptCommand,Set,SetSessionCharacteristics,TransactionCommand
A prepared statement.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected booleanWhether to create a new object (for indexes).The list of parameters.protected booleanIf the query should be prepared before each execution.protected SessionLocalThe session.protected StringThe SQL string.The SQL tokens. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidCheck if this statement was canceled.protected voidCheck if all parameters have been set.voidcollectDependencies(HashSet<DbObject> dependencies) Find and collect all DbObjects, this Prepared depends on.longGet the current row number.protected final Databaseprotected intGet the current object id, or get a new id from the database.Get the parameter list.intGet the object id to use for the database object that is created in this statement.final StringgetPlanSQL(int sqlFlags) Get the SQL statement with the execution plan.getPlanSQL(StringBuilder builder, int sqlFlags) Appends the SQL statement with the execution plan.final SessionLocalstatic StringgetSimpleSQL(Expression[] list) Get the SQL snippet of the expression list.final StringgetSQL()Get the SQL statement.Get the SQL tokens.abstract intgetType()Get the command type as defined in CommandInterfacevoidinvalidateCachedResult(Table reason) booleanbooleanisQuery()Check if this object is a query.booleanCheck if this command is read only.booleanReturns is this command can be repeated on locking failure.abstract booleanCheck if this command is transactional.booleanReturns whether values of parameters were specified in SQL.booleanCheck if the statement needs to be re-compiled.voidprepare()Prepare this statement.query(long maxrows) Execute the query.abstract ResultInterfaceGet an empty result set containing the metadata.voidsetCommand(Command command) Set the command.voidsetCurrentRowNumber(long rowNumber) Set the current row number.voidsetParameterList(ArrayList<Parameter> parameters) Set the parameter list of this statement.voidsetPersistedObjectId(int i) Set the persisted object id for this statement.voidsetPrepareAlways(boolean prepareAlways) Set the prepare always flag.protected final DbExceptionsetRow(DbException e, long rowId, String values) Set the SQL statement of the exception to the given row.voidsetSession(SessionLocal currentSession) Set the session for this statement.final voidSet the SQL statement.voidsetWithParamValues(boolean withParamValues) Sets whether values of parameters were specified in SQL.toString()Convert the statement to a String.longupdate()Execute the statement.
-
Field Details
-
session
The session. -
sqlStatement
The SQL string. -
sqlTokens
The SQL tokens. -
create
protected boolean createWhether to create a new object (for indexes). -
parameters
The list of parameters. -
prepareAlways
protected boolean prepareAlwaysIf the query should be prepared before each execution. This is set for queries with LIKE ?, because the query plan depends on the parameter value.
-
-
Constructor Details
-
Prepared
Create a new object.- Parameters:
session- the session
-
-
Method Details
-
isTransactional
public abstract boolean isTransactional()Check if this command is transactional. If it is not, then it forces the current transaction to commit.- Returns:
- true if it is
-
queryMeta
Get an empty result set containing the metadata.- Returns:
- the result set
-
getType
public abstract int getType()Get the command type as defined in CommandInterface- Returns:
- the statement type
-
isReadOnly
public boolean isReadOnly()Check if this command is read only.- Returns:
- true if it is
-
needRecompile
public boolean needRecompile()Check if the statement needs to be re-compiled.- Returns:
- true if it must
-
setParameterList
Set the parameter list of this statement.- Parameters:
parameters- the parameter list
-
getParameters
Get the parameter list.- Returns:
- the parameter list
-
isWithParamValues
public boolean isWithParamValues()Returns whether values of parameters were specified in SQL.- Returns:
- are values of parameters were specified in SQL
-
setWithParamValues
public void setWithParamValues(boolean withParamValues) Sets whether values of parameters were specified in SQL.- Parameters:
withParamValues- are values of parameters were specified in SQL
-
checkParameters
protected void checkParameters()Check if all parameters have been set.- Throws:
DbException- if any parameter has not been set
-
setCommand
Set the command.- Parameters:
command- the new command
-
isQuery
public boolean isQuery()Check if this object is a query.- Returns:
- true if it is
-
prepare
public void prepare()Prepare this statement. -
update
public long update()Execute the statement.- Returns:
- the update count
- Throws:
DbException- if it is a query
-
query
Execute the query.- Parameters:
maxrows- the maximum number of rows to return- Returns:
- the result set
- Throws:
DbException- if it is not a query
-
setSQL
Set the SQL statement.- Parameters:
sql- the SQL statementsqlTokens- the SQL tokens
-
getSQL
Get the SQL statement.- Returns:
- the SQL statement
-
getSQLTokens
Get the SQL tokens.- Returns:
- the SQL tokens
-
getPersistedObjectId
public int getPersistedObjectId()Get the object id to use for the database object that is created in this statement. This id is only set when the object is already persisted. If not set, this method returns 0.- Returns:
- the object id or 0 if not set
-
getObjectId
protected int getObjectId()Get the current object id, or get a new id from the database. The object id is used when creating new database object (CREATE statement). This method may be called only once.- Returns:
- the object id
-
getPlanSQL
Get the SQL statement with the execution plan.- Parameters:
sqlFlags- formatting flags- Returns:
- the execution plan
-
getPlanSQL
Appends the SQL statement with the execution plan.- Parameters:
builder- string buildersqlFlags- formatting flags- Returns:
- the execution plan
-
checkCanceled
public void checkCanceled()Check if this statement was canceled.- Throws:
DbException- if it was canceled
-
setPersistedObjectId
public void setPersistedObjectId(int i) Set the persisted object id for this statement.- Parameters:
i- the object id
-
setSession
Set the session for this statement.- Parameters:
currentSession- the new session
-
setPrepareAlways
public void setPrepareAlways(boolean prepareAlways) Set the prepare always flag. If set, the statement is re-compiled whenever it is executed.- Parameters:
prepareAlways- the new value
-
setCurrentRowNumber
public void setCurrentRowNumber(long rowNumber) Set the current row number.- Parameters:
rowNumber- the row number
-
getCurrentRowNumber
public long getCurrentRowNumber()Get the current row number.- Returns:
- the row number
-
toString
Convert the statement to a String. -
getSimpleSQL
Get the SQL snippet of the expression list.- Parameters:
list- the expression list- Returns:
- the SQL snippet
-
setRow
Set the SQL statement of the exception to the given row.- Parameters:
e- the exceptionrowId- the row numbervalues- the values of the row- Returns:
- the exception
-
isCacheable
public boolean isCacheable() -
getSession
-
collectDependencies
Find and collect all DbObjects, this Prepared depends on.- Parameters:
dependencies- collection of dependencies to populate
-
getDatabase
-
isRetryable
public boolean isRetryable()Returns is this command can be repeated on locking failure.- Returns:
- is this command can be repeated on locking failure
-
invalidateCachedResult
-