我有一个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)
已经存在的文件提供路径,我觉得这是不正确的。我想要实际发生的是检查文件是否存在,如果存在,则应该用这个新内容覆盖该文件。
答案 0 :(得分:1)
您无法写入App Engine上的文件。您有两种选择:
将此文件存储为数据存储区中的长String对象(必须小于1MB)。
将其写入Google云端存储中的文件。