当前位置: 代码迷 >> Java Web开发 >> 结果集 java的File流 再上传到ftp!解决办法
  详细解决方案

结果集 java的File流 再上传到ftp!解决办法

热度:265   发布时间:2016-04-17 10:23:33.0
结果集 java的File流 再上传到ftp!
本人菜鸟,遇到以下问题:
1、项目要求:从数据库中查询数据,然后上传到FTP

2、现在我用的方式是用windows自带的定时任务,定时执行sql脚本,将查询的结果SPOOL到指定的文件夹下的自动生成的txt文件中,txt文件中显示的就是查询结果。以下是txt文件中显示的内容:
04525622121,张三,13329529555,20120111135947,20120111135947,1,,,04515622121,,0.10,1,1,4,0.10,1,,,,
04525622121,张四,13796851688,20120111135947,20120111135947,2,,,04515622121,,0.20,1,1,4,0.10,1,,,,
04525622121,张五,13234638555,20120111135947,20120111135947,1,,,04515622121,,0.10,1,1,4,0.10,1,,,,

3、项目经理要求改进,不用windows定时任务。
  要求如下:从数据库查询的结果集,用File流,然后再上传到ftp

我的问题:
1、我理解的是查到的结果集,用File流输出成txt文件。
那txt文件中显示的是什么?是二进制数还是跟我现在的形式一样就是正常的汉字?
我理解的对吗?不清楚用流干嘛?是生成文件,还是什么不生成文件把结果集保留到内存或别的地方。。。

2、为什么说这种方式比定时任务优化呢?

我是菜鸟,没怎么接触过文件流。请高手指点。

------解决方案--------------------
我不知道什么是定时任务,但是 文件流写数据到指定文件,是不是这个

private void recordSocre(int total) {
// TODO Auto-generated method stub
BufferedWriter bw = null;
try {
bw=new BufferedWriter(new OutputStreamWriter(new FileOutputStream("Socre.txt"),"utf-8"));
StringBuilder str=new StringBuilder();
long currenttime=System.currentTimeMillis();
Date time=new Date();
time.setTime(currenttime);
DateFormat fmt=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
String Time=fmt.format(time);
str.append(user.getId()).append(":").append(user.getName()).append(":").append(total).append(":").append(Time);
bw.write(str.toString());
bw.newLine();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
bw.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

}
  相关解决方案