从jsp下拉框获取数据库内容到servlet获取选择结果!

从jsp下拉框获取数据库内容到servlet获取选择结果!

Q:
如何从数据库里提取出学院名字(之所以不采用手动形式的下拉框是因为学院信息可能会变动 从数据库提取保证了信息的时效性准确性)显示在下拉框中(用于注册时供用户选择所属学院)

A: jsp中这么写(注意name属性写在select标签中,此name即为传回servlet的值)

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
 <% 
      DepartmentDAO dep=new DepartmentDAO();
      List<Department> list=dep.Department_information(); 
      request.setAttribute("list",list);           
      %>
          <tr>
                <td>&nbsp;&nbsp;&nbsp;院:</td>
                <lable>&nbsp;&nbsp;&nbsp;院:</lable>
                 <select name="dept_id">
                    <option value="">请选择:</option>
                  <c:forEach items="${list}" var="dep">
                    <option value="${dep.dept_id}">${dep.dept_name}</option>
                  </c:forEach>
                 </select>
            </tr>

Q:
如何在servlet中获取到从jsp传来的值?

A:因为在设计数据库的注册表时用到的属性时学院id,故在上述jsp中设置value为学院id。
!!!!!!name为传回来的学院id的变量名,value为变量的值。

  int dept_id=Integer.parseInt(request.getParameter("dept_id"));

反思:
这次在name和value的意义上使用错误,导致小小下拉框我一直都get不到我要的学院id 出错位在java类的getParameter那句语句。
为什么获取不到东西呢?一开始是这么写的:name位置错误

 <select >
                    <option value="">请选择:</option>
                  <c:forEach items="${list}" var="dep">
                    <option name="dept_id" value="${dep.dept_id}">${dep.dept_name}</option>
                  </c:forEach>
                 </select>

中间怀疑人生甚至在option里加了id排列组合试了好几次都报500…结果是name位置不对导致…在这块花费了较大时间实属不该。写下这篇日志,铭记于心,此错再犯我就是狗!

  • 1
    点赞
  • 0
    评论
  • 4
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 1024 设计师:白松林 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值