JavaWeb实现学生信息管理系统(3)

 更新时间:2021年8月15日 20:01  点击:1970

本文接着第二篇,继续为大家分享了JavaWeb实现学生信息管理系统,供大家参考,具体内容如下

今日任务:实现学生管理系统的删除、更新、修改和模糊查询功能!

一、删除学生信息

点击超链接,弹出一个询问是否删除的对话框,如果点击了确定,删除此学生的信息。

1. 超链接执行一个js方法

<a href="#" rel="external nofollow"  onclick="doDelete(${stu.sid})">删除</a>

在doDelete()方法里判断点击的选项,然后跳转到DeleteServlet。

<script type="text/javascript">
 function doDelete(sid){
  //如果这里弹出的对话框,用户点击的是确定,就去请求servlet
  var flag = confirm("确定删除?");
  if(flag){
   //表明确定删除。则访问servlet,在当前标签页上打开超链接
   window.location.href = "DeleteServlet?sid="+sid;
  }
 }
</script>

2. DeleteServlet收到了请求,然后去调用service,service去调用dao。

DeleteServlet.java

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  
  try {
   //1.接受id
   int sid = Integer.parseInt(request.getParameter("sid"));
   
   //2.执行删除
   StudentService service = new StudentServiceImpl();
   service.delete(sid);
   
   //3.跳转到列表页
   request.getRequestDispatcher("StudentListServlet").forward(request,response);
  } catch (SQLException e) {
   e.printStackTrace();
  }
 }

StudentDao.java & StudentService.java

 /**
  * 根据id删除学生
  * @param sid
  * @throws SQLException
  */
 void delete(int sid) throws SQLException;

StudentDaoImpl.java & StudentServiceImpl.java

public class StudentDaoImpl implements StudentDao {
 
 @Override
 public void delete(int sid) throws SQLException {
  QueryRunner runner = new QueryRunner(JDBCUtil02.getDataSource());
  String sql = "delete from stu where sid=?";
  runner.update(sql,sid);
  
 }

}

public class StudentServiceImpl implements StudentService{
 @Override
 public void delete(int sid) throws SQLException {
  StudentDao dao = new StudentDaoImpl();
  dao.delete(sid);
  
 } 
}

3. 删除结果如下:

删除id = 3的学生的信息


二、更新(修改)学生信息

1. 点击列表上的更新,跳转到EditServlet上

<a href="EditServlet?sid=${stu.sid }" rel="external nofollow" >更新</a>

2. 在EditServlet里面,根据id查询这个学生的所有信息

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  
  try {
   //1.接受id
   int sid = Integer.parseInt(request.getParameter("sid"));
   
   //2.查询学生数据
   StudentService service = new StudentServiceImpl();
   Student stu = service.findStudentById(sid);
   
   //3.显示数据
   //存数据
   request.setAttribute("stu", stu);
   //跳转
   request.getRequestDispatcher("edit.jsp").forward(request, response);
  } catch (SQLException e) {
   e.printStackTrace();
  }
  
  
 }

3. 跳转到更新页面edit.jsp,在edit.jsp上显示数据

原来的学生信息如图所示,我们修改编号为2的学生的电话为11111。
点击更新,跳转到该学生的修改页面,如下:

修改页面代码如下:

<body>

 <h3>更新学生页面</h3>
 
 <form action="UpdateServlet" method="post">
  <input type="hidden" name="sid" value="${stu.sid }">
  <table border="1" width="600">
   <tr>
    <td>姓名</td>
    <td><input type="text" name="sname" value="${stu.sname }"></td>
   </tr>
   <tr>
    <td>性别</td>
    <td>
     <!-- 
     如果性别是男的,可以在男的性别input标签里面出现checked;
     如果性别是女的,可以在女的性别input标签里面出现checked;
      -->
     <input type="radio" name="gender" value="男"
      <c:if test="${stu.gender == '男' }">checked</c:if>
     >男
     <input type="radio" name="gender" value="女"
      <c:if test="${stu.gender == '女' }">checked</c:if>
     >女
    </td>
   </tr>
   <tr>
    <td>电话</td>
    <td><input type="text" name="phone" value="${stu.phone }"></td>
   </tr>
   <tr>
    <td>生日</td>
    <td><input type="text" name="birthday" value="${stu.birthday }"></td>
   </tr>
   <tr>
    <td>爱好</td>
    <td>
     <!-- 
     例如:爱好有篮球,足球,看书
     由于爱好有很多歌,里面存在包含关系
      -->
     <input type="checkbox" name="hobby" value="游泳"
      <c:if test="${fn:contains(stu.hobby,'游泳') }">checked</c:if>
     >游泳
     <input type="checkbox" name="hobby" value="篮球"
      <c:if test="${fn:contains(stu.hobby,'篮球') }">checked</c:if>
     >篮球
     <input type="checkbox" name="hobby" value="足球"
      <c:if test="${fn:contains(stu.hobby,'足球') }">checked</c:if>
     >足球
     <input type="checkbox" name="hobby" value="看书"
      <c:if test="${fn:contains(stu.hobby,'看书') }">checked</c:if>
     >看书
     <input type="checkbox" name="hobby" value="写字"
      <c:if test="${fn:contains(stu.hobby,'写字') }">checked</c:if>
     >写字
    </td>
   </tr>
   <tr>
    <td>简介</td>
    <td>
     <textarea rows="3" cols="20" name="info">${stu.info }</textarea>
    </td>
   </tr>
   <tr>
    <td colspan="2"><input type="submit" value="更新"></td>
   </tr>
  </table>
 </form>
 

</body>

修改该学生的电话为11111,如下:

4. 修改完数据,提交数据到UpdateServlet

【备:代码与AddServlet代码相似,唯一的不同点就是:提交上来的数据是没有带id的,我们需要手动创建一个隐藏的输入框,在这里面给定id的值,以便提交表单时,带上id。

<input type="hidden" name="sid" value="${stu.sid }">

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  
  request.setCharacterEncoding("utf-8");
  try {
   //1.获取客户端提交上来的数据
   int sid = Integer.parseInt(request.getParameter("sid"));
   System.out.println(sid);
   String sname = request.getParameter("sname");
   System.out.println(sname);
   String gender = request.getParameter("gender");
   String phone = request.getParameter("phone");
   String birthday = request.getParameter("birthday");  //传过来是1989-10-18
   String info = request.getParameter("info");
    
   //String hobby = request.getParameter("hobby");
   String [] h = request.getParameterValues("hobby");
   //[篮球,足球,写字]-----篮球,足球,写字
   String hobby = Arrays.toString(h);
   hobby = hobby.substring(1,hobby.length()-1);
   
   //String-------Date
   Date date = new SimpleDateFormat("yyyy-MM-dd").parse(birthday);
   Student student = new Student(sid,sname,gender,phone,hobby,info,date);
   
   //2.更新数据库数据
   StudentService service = new StudentServiceImpl();
   service.update(student);
   
   //3.跳转界面
   request.getRequestDispatcher("StudentListServlet").forward(request, response);
  } catch (Exception e) {
   e.printStackTrace();
  }
  
 
 }

5. 获取数据,调用service,调用dao

StudentDao.java & StudentService.java

 /**
  * 更新学生信息
  * @param student  需要更新的学生数据
  * @throws SQLException
  */
 void update(Student student) throws SQLException;

StudentDaoImpl.java

public class StudentDaoImpl implements StudentDao {
 @Override
 public void update(Student student) throws SQLException {
  QueryRunner runner = new QueryRunner(JDBCUtil02.getDataSource());
  String sql = "update stu set sname=? , gender=? , phone=? , birthday=? , hobby=? , info=? where sid=?";
  runner.update(sql, 
    student.getSname(),
    student.getGender(),
    student.getPhone(),
    student.getBirthday(),
    student.getHobby(),
    student.getInfo(),
    student.getSid()
    
    );
  
 }

}

StudentServiceImpl.java

public class StudentServiceImpl implements StudentService{
 @Override
 public void update(Student student) throws SQLException {
  
  StudentDao dao = new StudentDaoImpl();
  dao.update(student);
 } 
}

6. 更新(修改)学生信息结果如下:

三、模糊查询

1. 在list.jsp加入进行查询的文本框

<form action="SearchStudentServlet" method="post">
 
  <table border="1" width="700">
   
   <tr>
    <td colspan="8">
     按姓名查询:<input type="text" name="sname"/>
     &nbsp;&nbsp;&nbsp;
     按性别查询:<select name="sgender">
         <option value="">--请选择--
         <option value="男">男
         <option vale="女">女
        </select>
     &nbsp;&nbsp;&nbsp; 
     <input type="submit" value="查询">
     &nbsp;&nbsp;&nbsp;
     <a href="add.jsp" rel="external nofollow" >添加</a>
    </td>
   </tr>
  </table>
 </form>

实现效果如下图所示:

2. 在SearchServlet里面,查询符合查询条件的学生信息

代码实现如下:

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  
  request.setCharacterEncoding("utf-8");
  try {
   //1.取到了要查询的关键数据:姓名,性别
   String sname = request.getParameter("sname");
   String sgender = request.getParameter("sgender");
   
   //2.查询
   StudentService service = new StudentServiceImpl();
   List<Student> list = service.searchStudent(sname, sgender);
   
   request.setAttribute("list", list);
   
   //3.跳转界面--列表界面
   request.getRequestDispatcher("list.jsp").forward(request, response);
  } catch (SQLException e) {
   e.printStackTrace();
  }
  
 }

例如:查询所有性别为男的学生信息;

查询结果如下:

3. 获取数据,调用service,调用dao

StudentDao.java & StudentService.java

/**
  * 模糊查询,根据姓名或者根据性别,或者两者兼有
  * @param sname
  * @param sgender
  * @return  List<Student>
  * @throws SQLException
  */
 List<Student> searchStudent(String sname,String sgender) throws SQLException;

StudentDaoImpl.java【这是一个需要注意的部分!!!】

 @Override
 public List<Student> searchStudent(String sname, String sgender) throws SQLException {
  QueryRunner runner = new QueryRunner(JDBCUtil02.getDataSource());
  /**
   * 如果只有姓名 select * from stu where sname like?;
   * 如果只有性别 select * from stu where gender=?
   * 如果两个都有 select * from stu where sname like? and gender=?
   * 如果两个都没有就查询所有
   */
  String sql = "select * from stu where 1=1 ";
  List<String> list = new ArrayList<String>();
  
  //判断是否有姓名,如果有,就组拼到sql语句里
  if(!TestUtils.isEmpty(sname)) {
   sql = sql + "and sname like ?";
   list.add("%"+sname+"%");
  }
  //判断是否有性别,如果有,就组拼到sql语句里
  if(!TestUtils.isEmpty(sgender)) {
   sql = sql + "and gender = ?";
   list.add(sgender);
  }
  
  
  return runner.query(sql, new BeanListHandler<Student>(Student.class),list.toArray());
  
 }

StudentServiceImol…java

@Override
 public List<Student> searchStudent(String sname, String sgender) throws SQLException {
  StudentDao dao = new StudentDaoImpl();
  return dao.searchStudent(sname, sgender);
 }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持猪先飞。

[!--infotagslink--]

相关文章

  • python实现学生通讯录管理系统

    这篇文章主要为大家详细介绍了python实现学生通讯录管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-02-25
  • 护卫神 主机管理系统使用说明(MSSQL管理)

    护卫神·主机管理系统该版本支持在Windows Server 200320082012,含32位和64位,直接开设配置WEB站、FTP站,以及SQL Server和MySQL,是您开设和管理虚拟主机的绝好帮手。但是对于新用户可能在使用上有一些困难,因此请仔细阅读如下说明文档...2016-01-27
  • php需登录的文件上传管理系统

    本文给大家介绍一个不错的需要登录的php 文件上传管理系统,功能简单有需要了解的同学可参考。 代码如下<&#63;php$admin_pw="admin";//管理密码$uploaddir="upload";//上传目录session_start();if($_GET['action']=="g...2015-10-30
  • C++学生信息管理系统

    这篇文章主要为大家想详细介绍了C++学生信息管理系统的实现代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
  • C语言学生成绩管理系统小设计

    这篇文章主要为大家详细介绍了C语言学生成绩管理系统小设计,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
  • C#毕业设计之Winform零压健身房管理系统

    本文介绍了个人的《零压健身房管理系统(扁平化)》的基本流程和功能点的介绍,虚心接受各位的意见,欢迎在提出宝贵的意见,大家一起探讨学习...2021-09-26
  • JavaWeb实战之编写单元测试类测试数据库操作

    这篇文章主要介绍了JavaWeb实战之编写单元测试类测试数据库操作,文中有非常详细的代码示例,对正在学习javaweb的小伙伴们有很大的帮助,需要的朋友可以参考下...2021-04-22
  • C++顺序表实现图书管理系统

    这篇文章主要为大家详细介绍了C++顺序表实现图书管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-10-13
  • 基于python实现银行管理系统

    这篇文章主要介绍了基于python实现银行管理系统,文中有非常详细的代码示例,对正在学习python项目制作的小伙伴们有很好的帮助,需要的朋友可以参考下...2021-04-19
  • 详解Java如何使用集合来实现一个客户信息管理系统

    读万卷书不如行万里路,只学书上的理论是远远不够的,只有在实战中才能获得能力的提升,本篇文章手把手带你用Java 集合实现一个客户信息管理系统,大家可以在过程中查缺补漏,提升水平...2021-11-11
  • [原创]php+ajax实现模拟Win文件管理系统五

    [原创]php+ajax实现模拟Win文件管理系统 // 本教程由本站原创,转载请注明来处 作者:www.111cn.net 邮箱:drise@163.com QQ:271728967 // 就是deldir()函数了这个函数的...2016-11-25
  • NPOINT免费虚拟主机管理系统windows2003的安装方法【图文】第1/2页

    这是一款免费的虚拟主机管理系统,无限制,并可以二次开发...2016-01-27
  • C语言实现职工管理系统

    这篇文章主要为大家详细介绍了C语言实现职工管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
  • JAVA实战练习之图书管理系统实现流程

    随着网络技术的高速发展,计算机应用的普及,利用计算机对图书馆的日常工作进行管理势在必行,本篇文章手把手带你用Java实现一个图书管理系统,大家可以在过程中查缺补漏,提升水平...2021-10-21
  • Django后台管理系统的图文使用教学

    在本篇文章里小编给大家整理的是一篇关于Django后台管理系统的图文使用教学内容,需要的朋友们参考下。...2020-04-22
  • 基于SSM实现学生管理系统

    这篇文章主要为大家详细介绍了基于SSM实现学生管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-12-18
  • spring+mybatis实现图书管理系统

    这篇文章主要介绍了spring+mybatis实现图书管理系统...2020-06-18
  • C语言实现学生学籍管理系统

    这篇文章主要为大家详细介绍了C语言实现学生学籍管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
  • 护卫神 主机管理系统使用说明(主机管理)

    这篇文章主要介绍了护卫神 主机管理系统使用说明,主机管理的相关资料,需要的朋友可以参考下...2016-01-27
  • java基于jdbc实现简单学生管理系统

    本文主要主要介绍了java连接mysql数据库的一个简单学生系统,通过jdbc连接数据库。文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-10-25