2015-06-08 3 views
0

Я делаю программу, где я могу добавлять данные в БД через сервлет, но я не могу вернуть его из БД на HTML-страницу.Чтение данных из базы данных HeidiSQL в сервлет

Я использую HTML-страницу, некоторые JS и два сервлета: один для ввода данных в БД и этот сервлет для получения данных.

Я называю этот сервлет функцией JS, но я не могу сказать, почему debbugger показывает, что он пропускает весь код. Я использую Eclipse IDE.

import java.io.IOException; 
import java.io.PrintWriter; 
import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.PreparedStatement; 
import java.sql.ResultSet; 

import javax.servlet.ServletException; 
import javax.servlet.annotation.WebServlet; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 

/** 
* Servlet implementation class TodoDisplayServlet 
*/ 
@WebServlet("/TodoDisplayServlet") 
public class TodoDisplayServlet extends HttpServlet { 
private static final long serialVersionUID = 1L; 

/** 
* @see HttpServlet#HttpServlet() 
*/ 
public TodoDisplayServlet() { 
    super(); 
    // TODO Auto-generated constructor stub 
} 

/** 
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) 
*/ 
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
    try { 
    PreparedStatement stmt = null; 
    StringBuffer sb = new StringBuffer(); 

    Class.forName("com.mysql.jdbc.Driver"); 

    Connection con1 = null; 

     con1 = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/tododb2","targarian","liger"); 

     String query1 = "select fname, lname, email, pnum" + "from tododb2"; 


      stmt = (PreparedStatement) con1.createStatement(); 
      ResultSet rs = stmt.executeQuery(query1); 

      sb.append("<table>"); 
      while (rs.next()) { 
       sb.append("<tr>"); 

       sb.append("<td>"); 
       rs.getString(1); 
       sb.append("</td>"); 

       sb.append("<td>"); 
       rs.getString(2); 
       sb.append("</td>"); 

       sb.append("<td>"); 
       rs.getString(3); 
       sb.append("</td>"); 

       sb.append("<td>"); 
       rs.getString(4); 
       sb.append("</td>"); 

       sb.append("</tr>"); 

      sb.append("</table>"); 
      stmt.executeUpdate(); 
      stmt.close(); 
      } 


     PrintWriter writter = null; 
      writter = response.getWriter(); 
      writter.println(sb.toString()); 
    } 
    catch(Exception e) 
    { 
     System.out.println("Error :"+e.getMessage()); 
    } 
} 

/** 
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 
*/ 
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
    // TODO Auto-generated method stub 
} 

} 
+0

Вам нужно будет точно указать, какую ошибку вы получите, если кто-то сможет вам помочь. Ваш запрос выглядит неправильно. У вас нет места между 'pnum' и' from'. Сделайте это 'select fname, lname, email, pnum from tododb2'. Кроме того, из вашей строки подключения, похоже, что tododb2 может быть именем вашей базы данных. Это также имя таблицы, с которой вы пытаетесь выбрать эти значения? –

+0

Спасибо, много .. это было имя базы данных, как вы сказали .. ее работа сейчас .. Большое спасибо –

ответ

0

Проблема была в tododb2, которая была именем моей базы данных, а не именем моей таблицы. Большое спасибо. лось.