[英]HSQLDB over JDBC: execute SQL statements in batch
我需要从我的Java应用程序初始化数据库。 出于代码可维护性的原因,我想将SQL代码与Java代码分开维护(它目前在一个单独的源文件中)。
该文件的前几行如下:
-- 1 - Countries - COUNTRIES.DAT;
drop table Countries if exists;
create table Countries(
CID integer,
ECC varchar(2),
CCD varchar(1),
NAME varchar(50));
我从文件中读取SQL代码并将其存储在字符串中。 然后我做:
PreparedStatement stmt = dbConnection.prepareStatement(sqlString);
这失败,出现以下异常:
java.sql.SQLSyntaxErrorException: unexpected token: CREATE : line: 2
这看起来好像JDBC不喜欢单个PreparedStatement
多个SQL语句。 我也尝试过CallableStatement
和prepareCall()
,结果相同。
JDBC是否提供了一次性传递整个SQL脚本的方法?
JDBC标准(以及该标准的SQL标准)假定每个执行一个语句。 某些驱动程序可以选择允许在一次执行中执行多个语句,但从技术上讲,该选项违反了JDBC标准。 JDBC本身没有任何内容支持多语句脚本执行。
您需要自己分离语句(在;
),并单独执行它们,或者找到为您执行此操作的第三方工具(例如MyBatis ScriptRunner
)。
您可能还想看一下像flyway或liquibase这样的东西。
要运行硬编码/加载的文件查询,您可以使用如下执行 :
Statement stmt = null;
String query = "drop table Countries if exists;
create table Countries(
CID integer,
ECC varchar(2),
CCD varchar(1),
NAME varchar(50));";
try {
stmt = con.createStatement();
stmt.execute(query);
} catch (SQLException e ) {
JDBCTutorialUtilities.printSQLException(e);
} finally {
if (stmt != null) { stmt.close(); }
}
如果要运行动态查询,例如附加值,则必须使用PreparedStatement。 要从文件运行查询,建议不要在其中放置动态查询。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.