mysqlrrapacher-brew

Use MySQL database query results to plot R graph using RApache and Brew


I am trying to plot a graph using R which is populated by MySQL query results. I have the following code:

rs = dbSendQuery(con, "SELECT BuildingCode, AccessTime from access")
data = fetch(rs, n=-1)
x = data[,1]
y = data[,2]
cat(colnames(data),x,y)

This gives me an output of:

BuildingCode AccessTime TEST-0 TEST-1 TEST-2 TEST-3 TEST-4 14:40:59 07:05:00 20:10:59 08:40:00 07:30:59

But this is where I get stuck. I have idea how to pass the "cat" data into an R plot. I have spend hours searching online and most of the examples of R plots I have come across use read.tables(text=""). This is not feasible for me as the data has to come from a database and not be hard coded in. I also found something about saving the output as a CSV but MySQL can not overwrite existing files so after the code was executed once I was unable to do it again as a file already existed.

My question is, how can I use the "cat" data (or another way of doing it if there is a better way) to plot a graph using data that isn't hard coded?

Note: I am using RApache as my web server and I have installed the Brew package.


Solution

  • Make the plot using R and just pass the path to the file back in cat

    <%
    ## Your other code to get the data, assuming it gets a data.frame called data
    
    ## Plot code
    library(Cairo)
    myplotfilename <- "/path/to/dir/myplot.png"
    CairoPNG(filename = myplotfilename, width = 480, height = 480)
    plot(x=data[,1],y=data[,2])
    tmp <- dev.off()
    cat(myplotfilename)
    %>