0

特定の時間に自動的に位置に書き込むために、200近くのファイルを選択しました。Quartzスケジューラで個別のジョブ名を作成しました。ジョブは時間にトリガーされます。すべてのファイルが書き込まれた後でのみ、ファイルを読み取ることができます。1つのファイルを書き込んだ後、読み取ることができませんでした。1つのファイルが書き込まれた後、FileWriterを閉じました。ハードディスクに書き込まれたファイルにアクセスして読み取るための解決策は何ですか

File f = new File(directory.getAbsolutePath() + File.separatorChar + context.getTrigger()
        .getJobName() + ".sql");
System.out.println(f.getAbsolutePath());
fw = new FileWriter(f, true);
System.out.println("DBname is " + scheduleInfo.get("dbName"));
fw.append("CREATE DATABASE /*!32312 IF NOT EXISTS*/ `" + scheduleInfo.get("dbName") + "` /*!40100 DEFAULT CHARACTER SET latin1 */;\nUSE `"
        + scheduleInfo.get("dbName") + "`;\n");
ps1 = con.prepareStatement(dbname_exist);
ps1.setString(1, (String) scheduleInfo.get("dbName"));
rs1 = ps1.executeQuery();
if (rs1.next()) {
    backup_exits = true;

}

// if (br.readLine() == null||!backup_exits)
if (br.readLine() == null) {
    ps = con.prepareStatement(backup_data);
    ps.setString(1, (String) scheduleInfo.get("sch_id"));
    ps.executeUpdate();
    System.out.println("Failed to download file");
} else {
    while ((line = br.readLine()) != null) {
        System.out.println(line);
        fw.append(line + "\n");
    }
}

br.close();
fw.close();
4

1 に答える 1

0

ファイル outputstream が適切に閉じられていることを確認する必要があります。ファイルオブジェクトインスタンスもさらに閉じます

于 2010-04-03T20:47:06.567 に答える