Resultset
オブジェクトを使用してテーブルからレコードをフェッチし、CSVfileを作成するJavaストアドプロシージャがあります。
BLOB retBLOB = BLOB.createTemporary(conn, true, BLOB.DURATION_SESSION);
retBLOB.open(BLOB.MODE_READWRITE);
OutputStream bOut = retBLOB.setBinaryStream(0L);
ZipOutputStream zipOut = new ZipOutputStream(bOut);
PrintStream out = new PrintStream(zipOut,false,"UTF-8");
out.write('\ufeff');
out.flush();
zipOut.putNextEntry(new ZipEntry("filename.csv"));
while (rs.next()){
out.print("\"" + rs.getString(i) + "\"");
out.print(",");
}
out.flush();
zipOut.closeEntry();
zipOut.close();
retBLOB.close();
return retBLOB;
ただし、生成されたCSVファイルには正しいドイツ語の文字が表示されません。OracleデータベースにもNLS_CHARACTERSET
UTF8の値があります。
提案してください。