JDBCを使用してファイルからPostgreSQLDBにデータをコピーしたい。JDBCステートメントオブジェクトを使用してファイルをDBにコピーしていました。とても遅いです。
copyoutコマンドを使用してファイルをDBにコピーすることもできることを知りました。しかし、JDBCを使用してそれを行うにはどうすればよいですか。JDBCでのコピーの例がある優れた参考資料でさえ役立つでしょう。
PS:よろしくお願いします
JDBCを使用してファイルからPostgreSQLDBにデータをコピーしたい。JDBCステートメントオブジェクトを使用してファイルをDBにコピーしていました。とても遅いです。
copyoutコマンドを使用してファイルをDBにコピーすることもできることを知りました。しかし、JDBCを使用してそれを行うにはどうすればよいですか。JDBCでのコピーの例がある優れた参考資料でさえ役立つでしょう。
PS:よろしくお願いします
これは動作します...
import java.io.FileReader;
import java.sql.Connection;
import java.sql.DriverManager;
import org.postgresql.copy.CopyManager;
import org.postgresql.core.BaseConnection;
public class PgSqlJdbcCopyStreamsExample {
public static void main(String[] args) throws Exception {
if(args.length!=4) {
System.out.println("Please specify database URL, user, password and file on the command line.");
System.out.println("Like this: jdbc:postgresql://localhost:5432/test test password file");
} else {
System.err.println("Loading driver");
Class.forName("org.postgresql.Driver");
System.err.println("Connecting to " + args[0]);
Connection con = DriverManager.getConnection(args[0],args[1],args[2]);
System.err.println("Copying text data rows from stdin");
CopyManager copyManager = new CopyManager((BaseConnection) con);
FileReader fileReader = new FileReader(args[3]);
copyManager.copyIn("COPY t FROM STDIN", fileReader );
System.err.println("Done.");
}
}
}
( aliasmrchipsの回答に基づく:) Groovy環境(ANT内で使用しているような)がある場合は、次のように実行できます(Oracleの仕様をPostgresに置き換えます)。
// exec.groovy
this.class.classLoader.rootLoader.addURL('${postgres-jdbc-driver-path}')
PgScript.load()
// PgScript.groovy
// (we cannot use the org.postgres.* classes in exec.groovy already!)
import java.io.FileReader
import java.sql.DriverManager
import org.postgresql.copy.CopyManager
import org.postgresql.core.BaseConnection
class PgScript {
static void load() {
DriverManager.getConnection (
'${jdbc-db-url}', '${db-usr}', '${db-usr-pass}'
).withCloseable {conn ->
new CopyManager((BaseConnection) conn).
copyIn('COPY t FROM STDIN', new FileReader('${sqlfile}'))
}
}
}
このjavaworld.comの記事にも基づいています。