Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/308.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/83.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java JDBC上的HSQLDB:批量执行SQL语句_Java_Sql_Jdbc_Hsqldb - Fatal编程技术网

Java JDBC上的HSQLDB:批量执行SQL语句

Java JDBC上的HSQLDB:批量执行SQL语句,java,sql,jdbc,hsqldb,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)); 我从文件中读取SQ

我需要从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脚本的方法?

要运行硬编码/加载自文件的查询,可以使用以下方法:

例如,如果您想运行动态查询以附加值,则必须使用PreparedStatement。对于从文件运行查询,不建议将动态查询放入其中。

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

您需要自己分离这些语句(在
上),并单独执行它们,或者找一个第三方工具为您执行这些语句(例如MyBatis
ScriptRunner


您可能还想看看flyway或liquibase之类的工具。

这在大多数数据库上都不起作用,因为JDBC要求每次执行一条语句(大多数驱动程序都遵循这一规则,并使用显式配置选项来违反规范)。
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(); }
}