java批量执行sql语句_java – 基于JDBC的HSQLDB:批量执行SQL语句

我需要从我的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这样的东西.

标签:java,sql,jdbc,hsqldb

来源: https://codeday.me/bug/20190628/1315677.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值