New servlet containing all survey results

This commit is contained in:
Imbus 2024-02-15 13:28:33 +01:00
parent 0043e3d9c0
commit 73c60d9c52
7 changed files with 183 additions and 19 deletions

View file

@ -25,6 +25,7 @@ dumptables:
sqlite3 $(DB_NAME) "SELECT * FROM Respondents;"
sqlite3 $(DB_NAME) "SELECT * FROM Answers;"
sqlite3 $(DB_NAME) "SELECT * FROM ProjectDetails;"
sqlite3 $(DB_NAME) "SELECT * FROM SurveyResults;"
# Phony targets
.PHONY: all init_db clean

View file

@ -1,18 +1,35 @@
CREATE TABLE IF NOT EXISTS Respondents (
name VARCHAR(255) PRIMARY KEY
);
CREATE TABLE
IF NOT EXISTS Respondents (name VARCHAR(255) PRIMARY KEY);
CREATE TABLE IF NOT EXISTS Answers (
CREATE TABLE
IF NOT EXISTS Answers (
answerOne INT,
answerTwo INT,
answerThree INT,
answerFour INT,
name VARCHAR(255),
FOREIGN KEY (name) REFERENCES Respondents(name)
name VARCHAR(255) NOT NULL,
projectName VARCHAR(255) NOT NULL,
FOREIGN KEY (name) REFERENCES Respondents (name),
FOREIGN KEY (projectName) REFERENCES ProjectDetails (projectName)
);
CREATE TABLE IF NOT EXISTS ProjectDetails (
projectID INT PRIMARY KEY,
projectName VARCHAR(255),
CREATE TABLE
IF NOT EXISTS ProjectDetails (
projectName VARCHAR(255) PRIMARY KEY,
projectDescription TEXT
);
CREATE VIEW
IF NOT EXISTS SurveyResults AS
SELECT
Respondents.name,
Answers.answerOne,
Answers.answerTwo,
Answers.answerThree,
Answers.answerFour,
Answers.projectName,
ProjectDetails.projectDescription
FROM
Respondents
JOIN Answers ON Respondents.name = Answers.name
JOIN ProjectDetails ON Answers.projectName = ProjectDetails.projectName;

View file

@ -66,8 +66,8 @@ public class Database implements AutoCloseable {
}
}
public boolean addAnswer(String name, String answerOne, String answerTwo, String answerThree, String answerFour) {
String sql = "insert into Answers (answerOne, answerTwo, answerThree, answerFour, name) values(?,?,?,?,?)";
public boolean addAnswer(String name, String projectName, String answerOne, String answerTwo, String answerThree, String answerFour) {
String sql = "insert into Answers (answerOne, answerTwo, answerThree, answerFour, name, projectName) values(?,?,?,?,?,?)";
try (PreparedStatement ps = conn.prepareStatement(sql)) {
ps.setString(1, answerOne);
@ -75,6 +75,7 @@ public class Database implements AutoCloseable {
ps.setString(3, answerThree);
ps.setString(4, answerFour);
ps.setString(5, name);
ps.setString(6, projectName);
ps.executeUpdate();
return true;
} catch (SQLException e) {
@ -86,7 +87,32 @@ public class Database implements AutoCloseable {
}
return false;
}
}
/**
* Get all the survey results from the database
*/
public SurveyResult[] getSurveyResults() {
String sql = "select * from SurveyResults";
try (Statement stmt = conn.createStatement()) {
ResultSet rs = stmt.executeQuery(sql);
SurveyResult[] results = new SurveyResult[100];
int i = 0;
while (rs.next()) {
String respName = rs.getString("name");
String projectName = rs.getString("projectName");
String projectDescription = rs.getString("projectDescription");
int[] data = { rs.getInt("answerOne"), rs.getInt("answerTwo"), rs.getInt("answerThree"),
rs.getInt("answerFour") };
results[i] = new SurveyResult(respName, projectName, projectDescription, data);
i++;
}
return results;
} catch (SQLException e) {
printSqlError(e);
return null;
}
}
private void printSqlError(SQLException e) {

View file

@ -56,4 +56,17 @@ public class FormGenerator {
return html;
}
public String resultsTable(SurveyResult[] results) {
String html = "<table border=" + formElement("1") + ">";
html += "<tr><th>Respondent</th><th>Project</th><th>Description</th><th>Factor 1</th><th>Factor 2</th><th>Factor 3</th><th>Factor 4</th></tr>";
for (SurveyResult result : results) {
if (result == null)
break;
html += "<tr><td>" + result.getName() + "</td><td>" + result.getProjectName() + "</td><td>"
+ result.getProjectDesc() + "</td><td>" + result.getData()[0] + "</td><td>" + result.getData()[1]
+ "</td><td>" + result.getData()[2] + "</td><td>" + result.getData()[3] + "</td></tr>";
}
html += "</table>";
return html;
}
}

View file

@ -0,0 +1,67 @@
package servlet;
import java.io.*;
import java.sql.SQLException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class Results.
*
* This class is responsible for displaying the results of the survey.
* It should be able to display the results of the survey in a table.
*/
@WebServlet("/Results")
public class Results extends HttpServlet {
private static final long serialVersionUID = 1L;
private Database db = new Database();
private FormGenerator formGenerator = new FormGenerator();
/**
* Default constructor.
*/
public Results() {
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
* response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
SurveyResult[] results = db.getSurveyResults();
// SurveyResult[] results = {
// new SurveyResult("John", "Project 1", new int[] { 1, 2, 3, 4 }),
// new SurveyResult("Jane", "Project 2", new int[] { 5, 6, 7, 8 }),
// new SurveyResult("Joe", "Project 3", new int[] { 9, 10, 1, 2 }),
// new SurveyResult("Jill", "Project 4", new int[] { 3, 4, 5, 6 }),
// new SurveyResult("Jack", "Project 5", new int[] { 7, 8, 9, 10 }),
// };
for (SurveyResult result : results) {
if (result == null)
break;
System.out.println(result.toString());
}
// Get a writer
PrintWriter out = response.getWriter();
out.println(formGenerator.resultsTable(results));
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse
* response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}

View file

@ -105,6 +105,7 @@ public class Survey extends HttpServlet {
name = (String) session.getAttribute("name");
String description = request.getParameter("proj_desc");
String proj_name = request.getParameter("proj_name");
session.setAttribute("proj_name", proj_name);
System.out.println("description: " + description);
if (description != null) {
state = NEED_PROJECT_DATA;
@ -138,11 +139,14 @@ public class Survey extends HttpServlet {
// display the next page
if (valuesOk) {
int sum = s11 + s12 + s13 + s14;
db.addAnswer(name, s11String, s12String, s13String, s14String);
// db.addAnswer(name, s11String, s12String, s13String, s14String);
db.addAnswer(name, (String) session.getAttribute("proj_name"), s11String, s12String, s13String,
s14String);
// This is only to show that it is possible to do something with the values.
// It is of course meaningless to calculate the sum.
out.println("<p> Hello " + name);
out.println("<p> The sum of the values you entered is " + sum);
out.println("<p>To view other results, click <a href=\"Results\">here</a>");
sessionShouldBeEnded = true;
} else {
out.println("The values you entered were not OK");

View file

@ -0,0 +1,36 @@
package servlet;
public class SurveyResult {
private String respName;
private String projectName;
private String projectDesc;
private int[] data;
public SurveyResult(String respName, String projectName, String projectDesc, int[] data) {
this.respName = respName;
this.projectName = projectName;
this.projectDesc = projectDesc;
this.data = data;
}
public String getName() {
return respName;
}
public String getProjectName() {
return projectName;
}
public String getProjectDesc() {
return projectDesc;
}
public int[] getData() {
return data;
}
public String toString() {
return String.format("Name: %s, Project: %s, Project Description: %s, Data: %d, %d, %d, %d", respName,
projectName, projectDesc, data[0], data[1], data[2], data[3]);
}
}