使用app engine java servlet动态创建和存储csv文件

时间:2015-03-22 22:37:35

标签: java mysql google-app-engine servlets amcharts

我有一个java web应用程序,它使用amCharts来绘制数据。我想要绘制的数据存储在SQL数据库中。我有一个servlet,它在数据库中查询我想要绘制的数据并将其格式化为逗号分隔的csv格式。我遇到问题的部分是在创建文件后将此格式化数据存储到文件中,然后能够稍后(通过真实路径)访问此文件,以便我可以更新图形。

这是我目前为servlet所做的:

public class CreateCsvServlet extends HttpServlet{

public void doGet(HttpServletRequest req, HttpServletResponse response)  throws IOException, ServletException{
    String macAdd = (String) req.getSession().getAttribute("macAddress");

    String path =  getServletContext().getRealPath("/powerData.txt");   //the file "powerData.txt" is an empty file that was deployed with the web app

    final String DB_URL="jdbc:google:mysql://mydatabase:iot?user=root";
    Statement stmt = null;
    Connection conn = null;            

      try{
         // Register JDBC driver
         Class.forName("com.mysql.jdbc.GoogleDriver");

         // Open a connection
         conn = DriverManager.getConnection(DB_URL);

         // Execute SQL query
         stmt = conn.createStatement();

         String sql = "SELECT `wattSeconds`,`time` FROM `iot_data`.`Usage Data` WHERE `MACAddress`='" + macAdd +"'";

         rs = stmt.executeQuery(sql);

         PrintWriter csvWriter = new PrintWriter(new File(path));

         // Extract data from result set
         while(rs.next()){
            //Retrieve by column name
            String watt  = rs.getString("wattSeconds");
            String time = rs.getString("time");
            String row = watt + "," + time;

            csvWriter.println(row) ;
         } 

         csvWriter.close(); 

         // Clean-up environment
         rs.close();
         stmt.close();
         conn.close();
      }catch(SQLException se){
         //Handle errors for JDBC
         se.printStackTrace();
      }

我正在尝试使用PrintWriter写入文件,但我不确定这是否是正确的方法。此外,我正在为new File(path)已经存在的文件提供路径,我觉得这是不正确的。我想要实际发生的是检查文件是否存在,如果存在,则应该用这个新内容覆盖该文件。

1 个答案:

答案 0 :(得分:1)

您无法写入App Engine上的文件。您有两种选择:

  1. 将此文件存储为数据存储区中的长String对象(必须小于1MB)。

  2. 将其写入Google云端存储中的文件。