gpt4 book ai didi

java - 基于 JDBC 的 HSQLDB : execute SQL statements in batch

转载 作者:搜寻专家 更新时间:2023-11-01 03:02:35 25 4
gpt4 key购买 nike

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

最佳答案

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

你需要自己将语句分开(在;上),并单独执行它们,或者找一个第三方工具为你做这件事(例如MyBatis ScriptRunner).

您可能还想看看 flyway 或 liquibase 之类的东西。

关于java - 基于 JDBC 的 HSQLDB : execute SQL statements in batch,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31895502/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com