我有一个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)
提供了一个已经存在的文件的路径,我觉得这是不正确的。我想要实际发生的是检查文件是否存在,如果存在,它应该用这个新内容覆盖文件。
您无法写入应用程序引擎上的文件。你有两个选择:
-
将此文件作为长字符串对象存储在数据存储中(它必须低于1MB)。
-
将其写入谷歌云存储中的文件。