我有一个使用Spring、Hibernate和PostgreSQL的项目,必须使用ANT来使用数据创建模式:
<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>但我知道这个错误:
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类?
发布于 2014-04-24 01:18:04
PgJDBC不直接支持COPY,但它通过从PgJDBC返回的java.sql.Connection的PGConnection接口获得的CopyManager API实现。
不幸的是,您不能在普通的SQL文件中使用COPY操作和其他命令。
就我个人而言,我会使用Ant psql任务来运行.sql文件。这样,就可以将COPY数据内联地包含在您的SQL文件中。
启用PgJDBC来处理COPY是件好事,但这并不容易。在PostgreSQL中,它实际上是一种不同的协议模式,对于它使用常规的JDBC接口和准备好的语句、执行等等没有多大意义。我们可以在自定义的execSQLScript上提供一个PGconnection,但这不会对您有多大帮助,因为像Ant的<sql>任务这样的东西不会使用它。您必须编写一个自定义任务。
相反,PgJDBC必须对客户撒谎--当它在COPY命令之后进入COPY模式时,它必须忽略JDBC,而不是真正做它在响应JDBC语句执行时应该做的事情。这可能会破坏所有的东西。
因此,到目前为止,最简单的选择是只执行psql命令来执行您想做的事情。
https://stackoverflow.com/questions/23230148
复制相似问题