Class ScriptUtils
Mainly for internal use within the framework.
- Since:
- 5.3
- Author:
- Thomas Risberg, Sam Brannen, Juergen Hoeller, Keith Donald, Dave Syer, Chris Beams, Oliver Gierke, Chris Baldwin, Nicolas Debeissat, Phillip Webb, Mark Paluch
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringDefault end delimiter for block comments within SQL scripts:"*/".static final StringDefault start delimiter for block comments within SQL scripts:"/*".static final String[]Default prefixes for single-line comments within SQL scripts:["--"].static final StringDefault statement separator within SQL scripts:";".static final StringEnd of file (EOF) SQL statement separator:"^^^ END OF SCRIPT ^^^".static final StringFallback statement separator within SQL scripts:"\n".
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic reactor.core.publisher.Mono<Void>executeSqlScript(Connection connection, Resource resource) Execute the given SQL script using default settings for statement separators, comment delimiters, and exception handling flags.static reactor.core.publisher.Mono<Void>executeSqlScript(Connection connection, EncodedResource resource) Execute the given SQL script using default settings for statement separators, comment delimiters, and exception handling flags.static reactor.core.publisher.Mono<Void>executeSqlScript(Connection connection, EncodedResource resource, DataBufferFactory dataBufferFactory, boolean continueOnError, boolean ignoreFailedDrops, String[] commentPrefixes, String separator, String blockCommentStartDelimiter, String blockCommentEndDelimiter) Execute the given SQL script.static reactor.core.publisher.Mono<Void>executeSqlScript(Connection connection, EncodedResource resource, DataBufferFactory dataBufferFactory, boolean continueOnError, boolean ignoreFailedDrops, String commentPrefix, String separator, String blockCommentStartDelimiter, String blockCommentEndDelimiter) Execute the given SQL script.
- 
Field Details- 
DEFAULT_STATEMENT_SEPARATORDefault statement separator within SQL scripts:";".- See Also:
 
- 
FALLBACK_STATEMENT_SEPARATORFallback statement separator within SQL scripts:"\n".Used if neither a custom separator nor the DEFAULT_STATEMENT_SEPARATORis present in a given script.- See Also:
 
- 
EOF_STATEMENT_SEPARATOREnd of file (EOF) SQL statement separator:"^^^ END OF SCRIPT ^^^".This value may be supplied as the separatortoexecuteSqlScript(Connection, EncodedResource, DataBufferFactory, boolean, boolean, String[], String, String, String)to denote that an SQL script contains a single statement (potentially spanning multiple lines) with no explicit statement separator. Note that such a script should not actually contain this value; it is merely a virtual statement separator.- See Also:
 
- 
DEFAULT_COMMENT_PREFIXESDefault prefixes for single-line comments within SQL scripts:["--"].
- 
DEFAULT_BLOCK_COMMENT_START_DELIMITERDefault start delimiter for block comments within SQL scripts:"/*".- See Also:
 
- 
DEFAULT_BLOCK_COMMENT_END_DELIMITERDefault end delimiter for block comments within SQL scripts:"*/".- See Also:
 
 
- 
- 
Constructor Details- 
ScriptUtilspublic ScriptUtils()
 
- 
- 
Method Details- 
executeSqlScriptpublic static reactor.core.publisher.Mono<Void> executeSqlScript(Connection connection, Resource resource) Execute the given SQL script using default settings for statement separators, comment delimiters, and exception handling flags.Statement separators and comments will be removed before executing individual statements within the supplied script. Warning: this method does not release the provided Connection.- Parameters:
- connection- the R2DBC connection to use to execute the script; already configured and ready to use
- resource- the resource to load the SQL script from; encoded with the current platform's default encoding
- Throws:
- ScriptException- if an error occurred while executing the SQL script
- See Also:
- 
- executeSqlScript(Connection, EncodedResource, DataBufferFactory, boolean, boolean, String[], String, String, String)
- DEFAULT_STATEMENT_SEPARATOR
- DEFAULT_COMMENT_PREFIXES
- DEFAULT_BLOCK_COMMENT_START_DELIMITER
- DEFAULT_BLOCK_COMMENT_END_DELIMITER
- ConnectionFactoryUtils.getConnection(io.r2dbc.spi.ConnectionFactory)
- ConnectionFactoryUtils.releaseConnection(io.r2dbc.spi.Connection, io.r2dbc.spi.ConnectionFactory)
 
 
- 
executeSqlScriptpublic static reactor.core.publisher.Mono<Void> executeSqlScript(Connection connection, EncodedResource resource) Execute the given SQL script using default settings for statement separators, comment delimiters, and exception handling flags.Statement separators and comments will be removed before executing individual statements within the supplied script. Warning: this method does not release the provided Connection.- Parameters:
- connection- the R2DBC connection to use to execute the script; already configured and ready to use
- resource- the resource (potentially associated with a specific encoding) to load the SQL script from
- Throws:
- ScriptException- if an error occurred while executing the SQL script
- See Also:
- 
- executeSqlScript(Connection, EncodedResource, DataBufferFactory, boolean, boolean, String[], String, String, String)
- DEFAULT_STATEMENT_SEPARATOR
- DEFAULT_COMMENT_PREFIXES
- DEFAULT_BLOCK_COMMENT_START_DELIMITER
- DEFAULT_BLOCK_COMMENT_END_DELIMITER
- ConnectionFactoryUtils.getConnection(io.r2dbc.spi.ConnectionFactory)
- ConnectionFactoryUtils.releaseConnection(io.r2dbc.spi.Connection, io.r2dbc.spi.ConnectionFactory)
 
 
- 
executeSqlScriptpublic static reactor.core.publisher.Mono<Void> executeSqlScript(Connection connection, EncodedResource resource, DataBufferFactory dataBufferFactory, boolean continueOnError, boolean ignoreFailedDrops, String commentPrefix, @Nullable String separator, String blockCommentStartDelimiter, String blockCommentEndDelimiter) Execute the given SQL script.Statement separators and comments will be removed before executing individual statements within the supplied script. Warning: this method does not release the provided Connection.- Parameters:
- connection- the R2DBC connection to use to execute the script; already configured and ready to use
- resource- the resource (potentially associated with a specific encoding) to load the SQL script from
- dataBufferFactory- the factory to create data buffers with
- continueOnError- whether to continue without throwing an exception in the event of an error
- ignoreFailedDrops- whether to continue in the event of specifically an error on a- DROPstatement
- commentPrefix- the prefix that identifies single-line comments in the SQL script (typically "--")
- separator- the script statement separator; defaults to ";" if not specified and falls back to "\n" as a last resort; may be set to "^^^ END OF SCRIPT ^^^" to signal that the script contains a single statement without a separator
- blockCommentStartDelimiter- the start block comment delimiter
- blockCommentEndDelimiter- the end block comment delimiter
- Throws:
- ScriptException- if an error occurred while executing the SQL script
- See Also:
 
- 
executeSqlScriptpublic static reactor.core.publisher.Mono<Void> executeSqlScript(Connection connection, EncodedResource resource, DataBufferFactory dataBufferFactory, boolean continueOnError, boolean ignoreFailedDrops, String[] commentPrefixes, @Nullable String separator, String blockCommentStartDelimiter, String blockCommentEndDelimiter) Execute the given SQL script.Statement separators and comments will be removed before executing individual statements within the supplied script. Warning: this method does not release the provided Connection.- Parameters:
- connection- the R2DBC connection to use to execute the script; already configured and ready to use
- resource- the resource (potentially associated with a specific encoding) to load the SQL script from
- dataBufferFactory- the factory to create data buffers with
- continueOnError- whether to continue without throwing an exception in the event of an error
- ignoreFailedDrops- whether to continue in the event of specifically an error on a- DROPstatement
- commentPrefixes- the prefixes that identify single-line comments in the SQL script (typically "--")
- separator- the script statement separator; defaults to ";" if not specified and falls back to "\n" as a last resort; may be set to "^^^ END OF SCRIPT ^^^" to signal that the script contains a single statement without a separator
- blockCommentStartDelimiter- the start block comment delimiter
- blockCommentEndDelimiter- the end block comment delimiter
- Throws:
- ScriptException- if an error occurred while executing the SQL script
- See Also:
 
 
-