首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用ant复制JDBC

用ant复制JDBC
EN

Stack Overflow用户
提问于 2014-04-22 21:03:14
回答 1查看 8.9K关注 0票数 1

我有一个使用Spring、Hibernate和PostgreSQL的项目,必须使用ANT来使用数据创建模式:

代码语言:javascript
复制
        <sql driver="org.postgresql.Driver"
            classpath="src/main/webapp/WEB-INF/lib/postgresql-9.1-901.jdbc4.jar"
            url="jdbc:postgresql://localhost:5433/postgres"
            userid="postgres"
            password="pw123"
            autocommit="true"
            src="src/main/sql/dbbackup.sql">
        </sql>

但我知道这个错误:

代码语言:javascript
复制
C:\Users\<user>\<workspace>\<Project>\antdb.xml:22: org.postgresql.util.PSQLException: ERROR: COPY from stdin failed: The JDBC driver currently does not support COPY operations.

不知道我们是否可以在这里使用postgresql.copy类?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-04-24 01:18:04

PgJDBC不直接支持COPY,但它通过从PgJDBC返回的java.sql.ConnectionPGConnection接口获得的CopyManager API实现。

不幸的是,您不能在普通的SQL文件中使用COPY操作和其他命令。

就我个人而言,我会使用Ant psql任务来运行.sql文件。这样,就可以将COPY数据内联地包含在您的SQL文件中。

启用PgJDBC来处理COPY是件好事,但这并不容易。在PostgreSQL中,它实际上是一种不同的协议模式,对于它使用常规的JDBC接口和准备好的语句、执行等等没有多大意义。我们可以在自定义的execSQLScript上提供一个PGconnection,但这不会对您有多大帮助,因为像Ant的<sql>任务这样的东西不会使用它。您必须编写一个自定义任务。

相反,PgJDBC必须对客户撒谎--当它在COPY命令之后进入COPY模式时,它必须忽略JDBC,而不是真正做它在响应JDBC语句执行时应该做的事情。这可能会破坏所有的东西。

因此,到目前为止,最简单的选择是只执行psql命令来执行您想做的事情。

票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23230148

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档