Class SQLExec
- All Implemented Interfaces:
- java.lang.Cloneable
public class SQLExec extends JDBCTask
Statements can either be read in from a text file using the src attribute or from between the enclosing SQL tags.
Multiple statements can be provided, separated by semicolons (or the defined delimiter). Individual lines within the statements can be commented using either --, // or REM at the start of the line.
The autocommit attribute specifies whether auto-commit should be turned on or off whilst executing the statements. If auto-commit is turned on each statement will be executed and committed. If it is turned off the statements will all be executed as one transaction.
The onerror attribute specifies how to proceed when an error occurs during the execution of one of the statements. The possible values are: continue execution, only show the error; stop execution and commit transaction; and abort execution and transaction and fail task.
- Since:
- Ant 1.2
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classSQLExec.DelimiterTypedelimiters we support, "normal" and "row"static classSQLExec.OnErrorThe action a task should perform on an error, one of "continue", "stop" and "abort"classSQLExec.TransactionContains the definition of a new transaction element.
- 
Field Summary
- 
Constructor SummaryConstructors Constructor Description SQLExec()
- 
Method SummaryModifier and Type Method Description voidadd(ResourceCollection rc)Adds a collection of resources (nested element).voidaddFileset(FileSet set)Adds a set of files (nested fileset attribute).voidaddText(java.lang.String sql)Set an inline SQL command to execute.SQLExec.TransactioncreateTransaction()Add a SQL transaction to executeprotected voidexecSQL(java.lang.String sql, java.io.PrintStream out)Exec the sql statement.voidexecute()Load the sql file and then execute itprotected java.sql.ConnectiongetConnection()Caches the connection returned by the base class's getConnection method.booleangetExpandProperties()is property expansion inside inline text enabled?protected java.sql.StatementgetStatement()Creates and configures a Statement instance which is then cached for subsequent calls.intlastDelimiterPosition(java.lang.StringBuffer buf, java.lang.String currentLine)protected voidprintResults(java.io.PrintStream out)Deprecated.since 1.6.x.protected voidprintResults(java.sql.ResultSet rs, java.io.PrintStream out)print any results in the result set.protected voidrunStatements(java.io.Reader reader, java.io.PrintStream out)read in lines and execute themvoidsetAppend(boolean append)whether output should be appended to or overwrite an existing file.voidsetCsvColumnSeparator(java.lang.String s)The column separator used when printing the results.voidsetCsvQuoteCharacter(java.lang.String s)The character used to quote column values.voidsetDelimiter(java.lang.String delimiter)Set the delimiter that separates SQL statements.voidsetDelimiterType(SQLExec.DelimiterType delimiterType)Set the delimiter type: "normal" or "row" (default "normal").voidsetEncoding(java.lang.String encoding)Set the file encoding to use on the SQL files read inprotected voidsetErrorProperty()voidsetErrorProperty(java.lang.String errorProperty)Property to set to "true" if a statement throws an error.voidsetEscapeProcessing(boolean enable)Set escape processing for statements.voidsetExpandProperties(boolean expandProperties)Enable property expansion inside nested textvoidsetForceCsvQuoteChar(boolean forceCsvQuoteChar)Force the csv quote charactervoidsetKeepformat(boolean keepformat)whether or not format should be preserved.voidsetOnerror(SQLExec.OnError action)Action to perform when statement fails: continue, stop, or abort optional; default "abort"voidsetOutput(java.io.File output)Set the output file; optional, defaults to the Ant log.voidsetOutput(Resource output)Set the output Resource; optional, defaults to the Ant log.voidsetOutputEncoding(java.lang.String outputEncoding)The encoding to use when writing the result to a resource.voidsetPrint(boolean print)Print result sets from the statements; optional, default falsevoidsetRawBlobs(boolean rawBlobs)Set whether to print raw BLOBs rather than their string (hex) representations.protected voidsetRowCountProperty(int rowCount)voidsetRowCountProperty(java.lang.String rowCountProperty)Sets a given property to the number of rows in the first statement that returned a row count.voidsetShowheaders(boolean showheaders)Print headers for result sets from the statements; optional, default true.voidsetShowtrailers(boolean showtrailers)Print trailing info (rows affected) for the SQL Addresses Bug/Request #27446voidsetShowWarnings(boolean b)whether to show SQLWarnings as WARN messages.voidsetSrc(java.io.File srcFile)Set the name of the SQL file to be run.voidsetStrictDelimiterMatching(boolean b)If false, delimiters will be searched for in a case-insensitive manner (i.e.voidsetTreatWarningsAsErrors(boolean b)Whether a warning is an error - in which case onError applies.protected voidsetWarningProperty()voidsetWarningProperty(java.lang.String warningProperty)Property to set to "true" if a statement produces a warning.Methods inherited from class org.apache.tools.ant.taskdefs.JDBCTaskaddConnectionProperty, createClasspath, getClasspath, getLoader, getLoaderMap, getPassword, getRdbms, getUrl, getUserId, getVersion, isAutocommit, isCaching, isValidRdbms, setAutocommit, setCaching, setClasspath, setClasspathRef, setDriver, setFailOnConnectionError, setPassword, setRdbms, setUrl, setUserid, setVersionMethods inherited from class org.apache.tools.ant.TaskbindToOwner, getOwningTarget, getRuntimeConfigurableWrapper, getTaskName, getTaskType, getWrapper, handleErrorFlush, handleErrorOutput, handleFlush, handleInput, handleOutput, init, isInvalid, log, log, log, log, maybeConfigure, perform, reconfigure, setOwningTarget, setRuntimeConfigurableWrapper, setTaskName, setTaskTypeMethods inherited from class org.apache.tools.ant.ProjectComponentclone, getDescription, getLocation, getProject, setDescription, setLocation, setProject
- 
Constructor Details- 
SQLExecpublic SQLExec()
 
- 
- 
Method Details- 
setSrcpublic void setSrc(java.io.File srcFile)Set the name of the SQL file to be run. Required unless statements are enclosed in the build file- Parameters:
- srcFile- the file containing the SQL command.
 
- 
setExpandPropertiespublic void setExpandProperties(boolean expandProperties)Enable property expansion inside nested text- Parameters:
- expandProperties- if true expand properties.
- Since:
- Ant 1.7
 
- 
getExpandPropertiespublic boolean getExpandProperties()is property expansion inside inline text enabled?- Returns:
- true if properties are to be expanded.
- Since:
- Ant 1.7
 
- 
addTextpublic void addText(java.lang.String sql)Set an inline SQL command to execute. NB: Properties are not expanded in this text unlessexpandPropertiesis set.- Parameters:
- sql- an inline string containing the SQL command.
 
- 
addFilesetAdds a set of files (nested fileset attribute).- Parameters:
- set- a set of files contains SQL commands, each File is run in a separate transaction.
 
- 
addAdds a collection of resources (nested element).- Parameters:
- rc- a collection of resources containing SQL commands, each resource is run in a separate transaction.
- Since:
- Ant 1.7
 
- 
createTransactionAdd a SQL transaction to execute- Returns:
- a Transaction to be configured.
 
- 
setEncodingpublic void setEncoding(java.lang.String encoding)Set the file encoding to use on the SQL files read in- Parameters:
- encoding- the encoding to use on the files
 
- 
setDelimiterpublic void setDelimiter(java.lang.String delimiter)Set the delimiter that separates SQL statements. Defaults to ";"; optionalFor example, set this to "go" and delimitertype to "ROW" for Sybase ASE or MS SQL Server. - Parameters:
- delimiter- the separator.
 
- 
setDelimiterTypeSet the delimiter type: "normal" or "row" (default "normal").The delimiter type takes two values - normal and row. Normal means that any occurrence of the delimiter terminate the SQL command whereas with row, only a line containing just the delimiter is recognized as the end of the command. - Parameters:
- delimiterType- the type of delimiter - "normal" or "row".
 
- 
setPrintpublic void setPrint(boolean print)Print result sets from the statements; optional, default false- Parameters:
- print- if true print result sets.
 
- 
setShowheaderspublic void setShowheaders(boolean showheaders)Print headers for result sets from the statements; optional, default true.- Parameters:
- showheaders- if true print headers of result sets.
 
- 
setShowtrailerspublic void setShowtrailers(boolean showtrailers)Print trailing info (rows affected) for the SQL Addresses Bug/Request #27446- Parameters:
- showtrailers- if true prints the SQL rows affected
- Since:
- Ant 1.7
 
- 
setOutputpublic void setOutput(java.io.File output)Set the output file; optional, defaults to the Ant log.- Parameters:
- output- the output file to use for logging messages.
 
- 
setOutputSet the output Resource; optional, defaults to the Ant log.- Parameters:
- output- the output Resource to store results.
- Since:
- Ant 1.8
 
- 
setOutputEncodingpublic void setOutputEncoding(java.lang.String outputEncoding)The encoding to use when writing the result to a resource.Default's to the platform's default encoding - Parameters:
- outputEncoding- the name of the encoding or null for the platform's default encoding
- Since:
- Ant 1.9.4
 
- 
setAppendpublic void setAppend(boolean append)whether output should be appended to or overwrite an existing file. Defaults to false.- Parameters:
- append- if true append to an existing file.
- Since:
- Ant 1.5
 
- 
setOnerrorAction to perform when statement fails: continue, stop, or abort optional; default "abort"- Parameters:
- action- the action to perform on statement failure.
 
- 
setKeepformatpublic void setKeepformat(boolean keepformat)whether or not format should be preserved. Defaults to false.- Parameters:
- keepformat- The keepformat to set
 
- 
setEscapeProcessingpublic void setEscapeProcessing(boolean enable)Set escape processing for statements.- Parameters:
- enable- if true enable escape processing, default is true.
- Since:
- Ant 1.6
 
- 
setRawBlobspublic void setRawBlobs(boolean rawBlobs)Set whether to print raw BLOBs rather than their string (hex) representations.- Parameters:
- rawBlobs- whether to print raw BLOBs.
- Since:
- Ant 1.7.1
 
- 
setStrictDelimiterMatchingpublic void setStrictDelimiterMatching(boolean b)If false, delimiters will be searched for in a case-insensitive manner (i.e. delimiter="go" matches "GO") and surrounding whitespace will be ignored (delimiter="go" matches "GO ").- Parameters:
- b- boolean
- Since:
- Ant 1.8.0
 
- 
setShowWarningspublic void setShowWarnings(boolean b)whether to show SQLWarnings as WARN messages.- Parameters:
- b- boolean
- Since:
- Ant 1.8.0
 
- 
setTreatWarningsAsErrorspublic void setTreatWarningsAsErrors(boolean b)Whether a warning is an error - in which case onError applies.- Parameters:
- b- boolean
- Since:
- Ant 1.8.0
 
- 
setCsvColumnSeparatorpublic void setCsvColumnSeparator(java.lang.String s)The column separator used when printing the results.Defaults to "," - Parameters:
- s- String
- Since:
- Ant 1.8.0
 
- 
setCsvQuoteCharacterpublic void setCsvQuoteCharacter(java.lang.String s)The character used to quote column values.If set, columns that contain either the column separator or the quote character itself will be surrounded by the quote character. The quote character itself will be doubled if it appears inside of the column's value. If this value is not set (the default), no column values will be quoted, not even if they contain the column separator. Note: BLOB values will never be quoted. Defaults to "not set" - Parameters:
- s- String
- Since:
- Ant 1.8.0
 
- 
setErrorPropertypublic void setErrorProperty(java.lang.String errorProperty)Property to set to "true" if a statement throws an error.- Parameters:
- errorProperty- the name of the property to set in the event of an error.
- Since:
- Ant 1.8.0
 
- 
setWarningPropertypublic void setWarningProperty(java.lang.String warningProperty)Property to set to "true" if a statement produces a warning.- Parameters:
- warningProperty- the name of the property to set in the event of a warning.
- Since:
- Ant 1.8.0
 
- 
setRowCountPropertypublic void setRowCountProperty(java.lang.String rowCountProperty)Sets a given property to the number of rows in the first statement that returned a row count.- Parameters:
- rowCountProperty- String
- Since:
- Ant 1.8.0
 
- 
setForceCsvQuoteCharpublic void setForceCsvQuoteChar(boolean forceCsvQuoteChar)Force the csv quote character- Parameters:
- forceCsvQuoteChar- boolean
 
- 
executeLoad the sql file and then execute it- Overrides:
- executein class- Task
- Throws:
- BuildException- on error.
 
- 
runStatementsprotected void runStatements(java.io.Reader reader, java.io.PrintStream out) throws java.sql.SQLException, java.io.IOExceptionread in lines and execute them- Parameters:
- reader- the reader contains sql lines.
- out- the place to output results.
- Throws:
- java.sql.SQLException- on sql problems
- java.io.IOException- on io problems
 
- 
execSQLprotected void execSQL(java.lang.String sql, java.io.PrintStream out) throws java.sql.SQLExceptionExec the sql statement.- Parameters:
- sql- the SQL statement to execute
- out- the place to put output
- Throws:
- java.sql.SQLException- on SQL problems
 
- 
printResults@Deprecated protected void printResults(java.io.PrintStream out) throws java.sql.SQLExceptionDeprecated.since 1.6.x. Usethe two arg versioninstead.print any results in the statement- Parameters:
- out- the place to print results
- Throws:
- java.sql.SQLException- on SQL problems.
 
- 
printResultsprotected void printResults(java.sql.ResultSet rs, java.io.PrintStream out) throws java.sql.SQLExceptionprint any results in the result set.- Parameters:
- rs- the resultset to print information about
- out- the place to print results
- Throws:
- java.sql.SQLException- on SQL problems.
- Since:
- Ant 1.6.3
 
- 
getConnectionprotected java.sql.Connection getConnection()Caches the connection returned by the base class's getConnection method.Subclasses that need to provide a different connection than the base class would, should override this method but keep in mind that this class expects to get the same connection instance on consecutive calls. returns null if the connection does not connect to the expected RDBMS. - Overrides:
- getConnectionin class- JDBCTask
- Returns:
- Connection the newly created connection or null if the connection failed and failOnConnectionError is false.
 
- 
getStatementprotected java.sql.Statement getStatement() throws java.sql.SQLExceptionCreates and configures a Statement instance which is then cached for subsequent calls.Subclasses that want to provide different Statement instances, should override this method but keep in mind that this class expects to get the same connection instance on consecutive calls. - Returns:
- Statement
- Throws:
- java.sql.SQLException- if statement creation or processing fails
 
- 
lastDelimiterPositionpublic int lastDelimiterPosition(java.lang.StringBuffer buf, java.lang.String currentLine)
- 
setErrorPropertyprotected final void setErrorProperty()
- 
setWarningPropertyprotected final void setWarningProperty()
- 
setRowCountPropertyprotected final void setRowCountProperty(int rowCount)
 
-