java在电力系统中关于把数据导出成e文件的记录

1. 定时任务执行特定操作
1.在tomcat启动时调用这个方法的全路径名

private void start() {
    //启动缓存
    cacheutil.init();
    //初始化数据源
    initDB();
    //初始化LBQ刷新服务
    com.binfo.service.lbq.LbqRefreshData.refreshLBQ();
    //当天0点定时上传上天的录播记录的信息
    com.binfo.service.lbq.LbqTreeAndGrid.upLoadLbxx();
}

2. 编写具体的操作方法

//每天0点上传昨天的昨天的录播信息数据
public static void upLoadLbxx() {
    //开启一个只有一个线程的线程池
    ScheduledExecutorService executor = Executors.newScheduledThreadPool(1);
    //执行间隔
    long oneDay = 24 * 60 * 60 * 1000;
    //初始化延迟
    long initDelay  = getTimeMillis("15:03:00") - System.currentTimeMillis();
    initDelay = initDelay > 0 ? initDelay : oneDay + initDelay;
    executor.scheduleAtFixedRate(
            //具体执行的线程
            new Runnable() {
                @Override
                public void run() {
                    //具体上传的方法
                    writeTxt();
                }
            },
            initDelay,
            oneDay,
            //计时单位
            TimeUnit.MILLISECONDS);
}

/**
 * 获取指定时间对应的毫秒数
 * @param time "HH:mm:ss"
 * @return
 */
private static long getTimeMillis(String time) {
    try {
        DateFormat dateFormat = new SimpleDateFormat("yy-MM-dd HH:mm:ss");
        DateFormat dayFormat = new SimpleDateFormat("yy-MM-dd");
        Date curDate = dateFormat.parse(dayFormat.format(new Date()) + " " + time);
        return curDate.getTime();
    } catch (ParseException e) {
        e.printStackTrace();
    }
    return 0;
}

/**
 * 这是具体上传数据的方法
 */
 
public static void writeTxt() {
    try {
        //获取昨天的时间
        Calendar cal=Calendar.getInstance();
        cal.add(Calendar.DATE,-1);
        Date d=cal.getTime();
        SimpleDateFormat sp=new SimpleDateFormat("yyyy-MM-dd");
        String yesterday=sp.format(d);
        //获取数据
        String sql="select * from JDBHAPP.FAULT_RECORD  where FAULTTIME='"+yesterday+"'";
        DataTable resultRecord = dbDao.select(sql);
        ///写入数据
        // 相对路径,如果没有则要建立一个新的output.txt文件
        File writeName = new File("../temp/mumengxiang.txt");
        // 创建新文件,有同名的文件的话直接覆盖
        writeName.createNewFile();
        try (FileWriter writer = new FileWriter(writeName);
             BufferedWriter out = new BufferedWriter(writer)
        ) {
            // \r\n即为换行
            //文件头
            String headTime=StringUtil.replace(yesterday,"-","");
            out.write("<!  system=继电保护系统  version=1.0  type=notype  code=GBK  data=1.0  datetime='"+headTime+"_00:00:00' !>\n" +
                    "<继电保护系统::"+headTime+"录播记录信息>\r\n");
            // 字段名称
            out.write("@");
            for(int i=0;i<resultRecord.getColumns().size();i++){
                out.write(resultRecord.getColumnName(i)+" ");
            }
            //结束
            out.write("\r\n ");
            //字段简介
            out.write("//主键值 时间戳 录播记录编号 故障时间毫秒值 主站名 变电站名 录播器名 一次设备名 故障识别 故障测距 录波器类型 对策故障记录ID 录波器测距结果 最低故障电压 最大故障电压 A相最大故障电流一次值 B相最大故障电流一次值 C相最大故障电流一次值 零序最大故障电流一次值 故障信息 数据文件是否存在 电压等级 故障记录对应文件名 上传时间\r\n ");
            //数据记录
            DataRowCollection rows = resultRecord.getRows();
            for (DataRow row: rows){
                out.write("#");
                for (int i = 0;i< 25 ; i++) {
                    out.write(row.getValue(i)+" ");
                }
                out.write("\r\n ");
            }
            //结束
            out.write("</继电保护系统::"+headTime+"录播记录信息>");
            // 把缓存区内容压入文件
            out.flush();
            out.close();
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
}
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: 使用java语言查询表数据导出csv文件可以使用Java语言提供的JDBC API和ResultSet类。首先,连接数据库,然后构建查询语句,接着使用ResultSet类检索查询结果,最后将结果写入CSV文件。 ### 回答2: 使用Java语言查询表数据导出CSV文件可以分为以下几个步骤: 1. 连接数据库:首先,需要在Java代码连接到数据库。可以使用Java提供的JDBC(Java Database Connectivity) API来连接到各种类型的数据库,如MySQL、Oracle等。需要设置连接URL、用户名和密码等数据库连接信息。 2. 执行查询语句:通过使用Java的JDBC API,可以执行SQL查询语句从表获取数据。可以使用预编译的语句来参数化查询语句,以便更安全和高效地执行查询操作。 3. 将查询结果写入CSV文件:在获取查询结果后,通过Java文件操作API,可以将查询结果写入CSV文件。可以使用Java的File类和相关的输入/输出流来创建、写入和关闭CSV文件。 4. CSV文件格式:CSV文件是以逗号分隔的文本文件,每行代表表的一条数据记录,每个字段之间使用逗号分隔。可以使用Java的字符串操作API来格式化数据并写入CSV文件。 5. 异常处理:在代码需要进行适当的异常处理,例如数据库连接失败、SQL语句执行错误或文件操作错误等。可以使用Java的异常处理机制(try-catch-finally)来捕获和处理异常,并在出现异常时进行适当的处理,如记录日志或回滚事务。 总结起来,使用Java语言查询表数据导出CSV文件,主要涉及到数据库连接、SQL查询、文件操作和异常处理等方面的知识。通过合理应用Java的API和相关技术,可以实现对表数据的查询和导出操作,生成符合CSV格式的文件。 ### 回答3: 在使用Java语言查询表数据导出为CSV文件之前,首先需要使用Java数据库连接(JDBC)驱动连接到数据库。可以选择合适的JDBC驱动程序来连接不同类型的数据库,比如MySQL、Oracle等。 然后,通过编写Java代码来执行SQL查询语句来获取表数据。可以使用PreparedStatement或Statement对象来执行查询,并通过ResultSet对象来获取查询结果的数据。 接下来,需要将查询结果的数据按照CSV文件的格式进行处理,即将每一行数据转换为以逗号分隔的字段。可以使用StringBuilder或StringBuffer来构建CSV文件的内容。 最后,将CSV文件内容写入到磁盘上的文件。可以使用FileWriter或BufferedWriter等类来实现文件的写入操作。在写入过程,需要注意处理异常和关闭文件资源。 以下是一种可能的实现方式: 1. 导入JDBC驱动: ```java import java.sql.*; ``` 2. 连接到数据库: ```java String url = "jdbc:mysql://localhost:3306/数据库名"; String User = "用户名"; String Password = "密码"; Connection conn = null; try { conn = DriverManager.getConnection(url, user, password); } catch (SQLException e) { e.printStackTrace(); } ``` 3. 执行SQL查询语句并获取结果: ```java String sql = "SELECT * FROM 表名"; Statement stmt = null; ResultSet rs = null; try { stmt = conn.createStatement(); rs = stmt.executeQuery(sql); // 处理查询结果,将数据转换为CSV格式 StringBuilder csvContent = new StringBuilder(); ResultSetMetaData metaData = rs.getMetaData(); int columnCount = metaData.getColumnCount(); // 写入CSV列名 for (int i = 1; i <= columnCount; i++) { csvContent.append(metaData.getColumnLabel(i)); if (i < columnCount) { csvContent.append(","); } } csvContent.append("\n"); // 写入CSV数据 while (rs.next()) { for (int i = 1; i <= columnCount; i++) { csvContent.append(rs.getString(i)); if (i < columnCount) { csvContent.append(","); } } csvContent.append("\n"); } // 将CSV内容写入文件 String csvFilePath = "导出文件路径"; BufferedWriter writer = null; try { writer = new BufferedWriter(new FileWriter(csvFilePath)); writer.write(csvContent.toString()); } catch (IOException e) { e.printStackTrace(); } finally { if (writer != null) { try { writer.close(); } catch (IOException e) { e.printStackTrace(); } } } } catch (SQLException e) { e.printStackTrace(); } finally { try { if (rs != null) { rs.close(); } if (stmt != null) { stmt.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } ``` 以上代码示例展示了如何使用Java语言查询表数据并将其导出为CSV文件。需要注意的是,代码数据库连接信息、SQL语句、导出文件路径等都需要根据实际情况进行修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值