Я разрабатываю приложение для голосования, в котором можно проголосовать за конкретный вариант и отправить его. Теперь я хочу, чтобы пользователь выбрал опцию внутри сервлета и сохранил ее как голосование в базе данных. И этот счет должен всегда увеличиваться на 1 при получении нового голоса. Но это не дает мне желаемый результат. Каждый раз, когда я выбираю опцию и нажимаю «Отправить», 1 вставляется в соответствующий столбец базы данных, как голосование. Я назвал параметры в качестве имен столбцов в БД. Я хочу, чтобы каждый новый голос был дополнением к его предыдущему значению
Ниже приводится страница Voting.jsp: -
<div class="card" style="width: 60rem; margin-left: 45px;">
<div class="card-body">
Click on one of the following options to caste your vote. Then click submit.
</div>
</div>
<div class="card" style="width: 60rem; margin-left: 45px;">
<div class="card-body">
<form action="SuccessServlet" method="post">
<label class="container">Team_1
<input type="radio" name="radio" value="team1">
<span class="checkmark"></span>
</label>
<label class="container">Team_2
<input type="radio" name="radio" value="team2">
<span class="checkmark"></span>
</label>
<label class="container">Team_3
<input type="radio" name="radio" value="team3">
<span class="checkmark"></span>
</label>
<label class="container">Team_4
<input type="radio" name="radio" value="team4">
<span class="checkmark"></span>
</label>
<button type="submit">Submit</button>
</form>
</div>
</div>
и мой класс сервлетов следующий: -
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
ud.setFirst_name(request.getParameter("f1"));
String answer = request.getParameter("radio");
if("team1".equals(answer)) {
System.out.println("Hello");
writeData1();
}
else if ("team2".equals(answer)) {
writeData2();
}
else if ("team3".equals(answer)) {
writeData3();
}
else if ("team4".equals(answer)) {
writeData4();
}
else {
response.sendRedirect("Success.jsp");
}
response.sendRedirect("UserPage.jsp");
}
}
public void writeData1() {
try {
Class.forName("com.mysql.cj.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/my_db?autoReconnect=true&useSSL=FALSE", "root", "root");
String query = "insert into Total_Votes(Team1) values(?)";
PreparedStatement ps = con.prepareStatement(query);
ps.setInt(1, 1);
ps.executeUpdate();
} catch (Exception e) {
// TODO Auto-generated catch block
System.out.println(e.getMessage());
}
}
public void writeData2() {
try {
Class.forName("com.mysql.cj.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/my_db?autoReconnect=true&useSSL=FALSE", "root", "root");
String query = "insert into Total_Votes(Team2) values(?)";
PreparedStatement ps = con.prepareStatement(query);
ps.setInt(1, 1);
ps.executeUpdate();
} catch (Exception e) {
// TODO Auto-generated catch block
System.out.println(e.getMessage());
}
}
public void writeData3() {
try {
Class.forName("com.mysql.cj.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/my_db?autoReconnect=true&useSSL=FALSE", "root", "root");
String query = "insert into Total_Votes(Team3) values(?)";
PreparedStatement ps = con.prepareStatement(query);
ps.setInt(1, 1);
ps.executeUpdate();
} catch (Exception e) {
// TODO Auto-generated catch block
System.out.println(e.getMessage());
}
}
public void writeData4() {
try {
Class.forName("com.mysql.cj.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/my_db?autoReconnect=true&useSSL=FALSE", "root", "root");
String query = "insert into Total_Votes(Team4) values(?)";
PreparedStatement ps = con.prepareStatement(query);
ps.setInt(1, 1);
ps.executeUpdate();
} catch (Exception e) {
// TODO Auto-generated catch block
System.out.println(e.getMessage());
}
}