HSQLDB over JDBC: 批量执行SQL条语句
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 脚本的方法?
要运行硬编码/从文件查询加载,您可以使用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。对于 运行 从文件中查询,不建议在其中放置动态查询。
JDBC 标准(以及与此相关的 SQL 标准)假定每次执行一条语句。一些驱动程序有一个选项允许在一次执行中执行多个语句,但从技术上讲,该选项违反了 JDBC 标准。 JDBC 本身没有任何支持多语句脚本执行的东西。
你需要自己将语句分开(在;
上),并单独执行它们,或者找一个第三方工具来为你做这件事(例如MyBatis ScriptRunner
)。
您可能还想看看 flyway 或 liquibase 之类的东西。
我需要从我的 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 脚本的方法?
要运行硬编码/从文件查询加载,您可以使用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。对于 运行 从文件中查询,不建议在其中放置动态查询。
JDBC 标准(以及与此相关的 SQL 标准)假定每次执行一条语句。一些驱动程序有一个选项允许在一次执行中执行多个语句,但从技术上讲,该选项违反了 JDBC 标准。 JDBC 本身没有任何支持多语句脚本执行的东西。
你需要自己将语句分开(在;
上),并单独执行它们,或者找一个第三方工具来为你做这件事(例如MyBatis ScriptRunner
)。
您可能还想看看 flyway 或 liquibase 之类的东西。