【问题标题】:To insert unchecked value of a check box into database [duplicate]将复选框的未选中值插入数据库[重复]
【发布时间】:2016-06-01 06:50:14
【问题描述】:

在使用 servlet 将复选框的未选中值插入 mysql 数据库时,我需要帮助。

工作流程:

1.从复选框值列表中,用户选中一些值,其余值设置为未选中

2.选择值后,用户点击保存按钮

3.点击保存按钮时,选中的值应该存储在一个表中,未选中的值应该存储在另一个表中

问题

我使用通用方法将值插入数据库,对我来说,检查的值被插入到一个表中(pdt_list)。同样我需要将未检查的值插入到另一个表中说(no_pdt_list)。单击保存按钮后,两次插入都应该发生。

这是我的代码

products.jsp

<%@page import="java.util.List"%>
    <%@page import="web.Products"%>
    <%@page import="java.util.ArrayList"%>
    <%@page contentType="text/html" pageEncoding="UTF-8"%>
    <!DOCTYPE html>
    <html>
     <form method="post" action="Save_Products">   
<b>          
            Brand Name:<font color="green">
            <% String brand_name=(String)session.getAttribute("brand_name");
       out.print(brand_name);%> 
        <c:set var="brand_name" value="brand_name" scope="session"  />
       </font></b>         
            <table>            
                <tr>                
                    <th> Products</th> 
                    <th> Description </th>
                </tr>
                <tr>
               <td> <b><%
      List<Products> pdts = (List<Products>) request.getAttribute("list");
      if(pdts!=null){
        for(Products prod: pdts){
           out.println("<input type=\"checkbox\" name=\"prod\" value=\""  + prod.getProductname() + "\">"  + prod.getProductname()+"<br>");
            } %> </b></td>   

            <td><%for(Products prod: pdts){
            out.println("<input type=\"text\" name=\"desc\" style=\"width:50px; height:22px\"/><br/>"); 
        } 

      }  
            %> </td>  

        </tr>
        <br/>
        <br/>
        <tr><td align="center">  <input type="submit" value="Save" name="save"/> </td></tr> 
            </table>
    </form>
    </body>
    </html>

Servlet 代码

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.sql.*;
import javax.servlet.RequestDispatcher;
import javax.servlet.http.HttpSession;


public class Save_Products extends HttpServlet {
 static final String dbURL = "jdbc:mysql://localhost:3306/pdt";
     static final String dbUser = "root";
     static final String dbPass = "root";
    @Override
     public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
         response.setContentType("text/html;charset=UTF-8");    
        PrintWriter out = response.getWriter();
            ResultSet rs=null;
            Connection connection = null;  
            try{
      HttpSession session = request.getSession();
    String brand_name =(String) session.getAttribute("brand_name");
String [] prod_list = request.getParameterValues("prod");
String [] desc_list = request.getParameterValues("desc");
Class.forName("com.mysql.jdbc.Driver");
connection = DriverManager.getConnection (dbURL,dbUser,dbPass);

String sql="insert into pdt_list(brand_name,product_name,desc)values(?,?,?)";
PreparedStatement prep = connection.prepareStatement(sql); 
int num_values = Math.min(prod_list.size(), desc_list.size());

int count_updated = 0;
for(int i = 0; i < num_values; i++){
    prep.setString(1, brand_name);
    prep.setString(2, prod_list[i]);
    prep.setString(3,desc_list[i]);
    count_updated += prep.executeUpdate();
}
if(count_updated>0)
{    
   out.print("Products Saved Successfully...");
 RequestDispatcher rd=request.getRequestDispatcher("Save_Success.jsp");    
            rd.forward(request,response);    
}
else{
    RequestDispatcher rd=request.getRequestDispatcher("Save_Failure.jsp");    
            rd.forward(request,response);   
}

prep.close();
       }
     catch(Exception E){
//Any Exceptions will be caught here
System.out.println("The error is"+E.getMessage());

    }  

        finally {
            try {
                connection.close();
            } 
        catch (Exception ex) {
                System.out.println("The error is"+ex.getMessage());
            }
                }

}

}

【问题讨论】:

    标签: mysql jsp servlets jdbc checkbox


    【解决方案1】:

    你也使用 Jquery 吗?你可以尝试这样做: $("input:checkbox:not(:checked)") 并将其保存在隐藏字段中,然后在您点击“保存”时提交表单...

    如果您的页面中有多个操作系统复选框,请务必引用您的复选框的名称。

    即:

    $("input#prod:not(:checked)").each(function(i){ console.log($(this).val()); //or save it to the hidden value with a comma or some sort of separator you can then work with at the servlet });

    【讨论】:

    • 单击保存按钮时,将调用 servlet。在 servlet 实现中,检查值应存储在一个表中,未检查值应存储在另一个表中。是否可以在单个 servlet 中处理两个表实施?
    • 嗯,我一直使用从 Servlets 或 AjaxServlets 调用的 SQLJ 文件来执行此操作,我认为它应该与 mySql 编码相同,只要您对打开和关闭连接进行适当的控制,您可以通过向 Servlet 添加私有方法并从 doPost 调用它们来更好地组织它...
    猜你喜欢
    • 2016-11-22
    • 2010-09-19
    • 2014-01-23
    • 2017-07-17
    • 1970-01-01
    相关资源
    最近更新 更多