我需要从我的Java应用程序初始化数据库.出于代码可维护性的原因,我想将SQL代码与Java代码分开维护(它目前在一个单独的源文件中).该文件的前几行如下:-- 1 - Countries - COUNTRIES.DAT;drop table Countries if e...
我需要从我的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 – 基于JDBC的HSQLDB:批量执行SQL语句
- springboot自带的缓存@EnableCaching用法 2023-04-16
- SpringBoot中@Import注解如何正确使用 2023-01-13
- jar包手动添加到本地maven仓库的步骤详解 2023-04-17
- springcloud安装rabbitmq并配置延迟队列插件的过程详解 2022-11-29
- Quarkus篇入门创建项目搭建debug环境 2022-10-24
- MyBatisCodeHelperPro最新激活方法(有效方法) 2022-09-03
- Lombok同时使⽤@Data和@Builder踩坑总结 2022-11-25
- SpringBoot底层注解超详细介绍 2023-06-06
- RocketMQ实现随缘分BUG小功能示例详解 2023-04-07
- java数据结构与算法数组模拟队列示例详解 2022-12-03