HSQLDB over JDBC:批量执行SQL语句

时间:2015-08-08 15:23:26

标签: java sql jdbc hsqldb

我需要从我的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语句。我也尝试了CallableStatementprepareCall(),结果相同。

JDBC是否提供了一次性传递整个SQL脚本的方法?

2 个答案:

答案 0 :(得分:3)

JDBC标准(以及该标准的SQL标准)假定每个执行一个语句。某些驱动程序可以选择允许在一次执行中执行多个语句,但从技术上讲,该选项违反了JDBC标准。 JDBC本身没有任何内容支持多语句脚本执行。

您需要自己分隔语句(在;上)并单独执行,或找到为您执行此操作的第三方工具(例如MyBatis ScriptRunner)。

你可能还想看看像flyway或liquibase这样的东西。

答案 1 :(得分:0)

要运行硬编码/加载的文件查询,您可以使用execute,如:

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。要从文件运行查询,建议不要在其中添加动态查询。