チャットを作ろうとしています。
jspで新規作成用のフォームを作っていてServletでデータベースの処理をしようとしているのですがうまくいきません。
以下のコードを使っています。
lang
1import java.io.IOException; 2import java.sql.Connection; 3import java.sql.DriverManager; 4import java.sql.ResultSet; 5import java.sql.SQLException; 6import java.sql.Statement; 7 8import javax.servlet.RequestDispatcher; 9import javax.servlet.ServletException; 10import javax.servlet.annotation.WebServlet; 11import javax.servlet.http.HttpServlet; 12import javax.servlet.http.HttpServletRequest; 13import javax.servlet.http.HttpServletResponse; 14 15/** 16 * Servlet implementation class Createchat 17 */ 18@WebServlet("/Createchat") 19public class Createchat extends HttpServlet { 20 private static final long serialVersionUID = 1L; 21 22 /** 23 * @see HttpServlet#HttpServlet() 24 */ 25 public Createchat() { 26 super(); 27 // TODO Auto-generated constructor stub 28 } 29 30 /** 31 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse 32 * response) 33 */ 34 protected void doGet(HttpServletRequest request, 35 HttpServletResponse response) throws ServletException, IOException { 36 RequestDispatcher dispatcher = request.getRequestDispatcher("/chat.jsp?room="+request.getAttribute("room_id")); 37 System.out.println("Kis-My-Ft2"); 38 dispatcher.forward(request,response); 39 } 40 41 /** 42 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse 43 * response) 44 */ 45 protected void doPost(HttpServletRequest request, 46 HttpServletResponse response) throws ServletException, IOException { 47 System.out.println("ジャニーズの交流サイト"); 48 request.setCharacterEncoding("UTF-8"); 49 Connection conn = null; 50 String url = "jdbc:mysql://localhost:3306/body"; 51 String user = "root"; 52 String password = "19850617"; 53 54 try { 55 Class.forName("com.mysql.jdbc.Driver").newInstance(); 56 57 conn = DriverManager.getConnection(url, user, password); 58 Statement stmt = conn.createStatement(); 59 String sql = "insert into room (title) values('"+request.getParameter("name")+"')"; 60 stmt.execute(sql); 61 sql = "SELECT room_id FROM room where title='"+request.getParameter("name")+"'"; 62 ResultSet rs; 63 rs = stmt.executeQuery(sql); 64 rs.next(); 65 sql = "create table chat"+rs.getInt("room_id")+"(name CHAR(200),comment CHAR(200),date TIMESTAMP(0) NOT NULL)"; 66 stmt.executeUpdate(sql); 67 request.setAttribute("room_id", rs.getInt("room_id")); 68 rs.close(); 69 } catch (ClassNotFoundException e) { 70 e.printStackTrace(); 71 } catch (SQLException e) { 72 e.printStackTrace(); 73 } catch (Exception e) { 74 e.printStackTrace(); 75 } finally { 76 try { 77 if (conn != null) { 78 conn.close(); 79 } 80 } catch (SQLException e) { 81 e.printStackTrace(); 82 } 83 } 84 doGet(request, response); 85 } 86 87}
実行したのですが以下のようなエラーが出ました。
Operation not allowed after ResultSet closed
確認したところテーブルは作成されていました。
どこが違うのでしょうか?
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2015/11/01 12:52