文档章节

jsp+servlet增删改查

小橙子的曼曼
 小橙子的曼曼
发布于 2018/08/07 20:58
字数 1634
阅读 298
收藏 2

1:首先根据数据库字段建立实体类

package ceet.ac.cn.model;
//数据封装类
public class Admin {  

    private int id;
    private String username;
    private String userpwd;

    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getUserpwd() {
        return userpwd;
    }
    public void setUserpwd(String userpwd) {
        this.userpwd = userpwd;
    }

}

2:建立数据库连接类

package ceet.ac.cn.dao;

import java.sql.Connection;
import java.sql.DriverManager;

public class DbHelper {
     private static String url = "jdbc:mysql://localhost:3306/admin";  //数据库地址
        private static String userName = "root";  //数据库用户名
        private static String passWord = "359129127";  //数据库密码
        private static Connection conn = null;

        private DbHelper(){

        }

        public static Connection getConnection(){
            if(null == conn){
                try {
                    Class.forName("com.mysql.jdbc.Driver");
                    conn = DriverManager.getConnection(url, userName, passWord);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
            return conn;
        }

        public static void main(String[] args) {  //测试数据库是否连通
            System.err.println(getConnection());
        }
}


3:建立dao层和dao的实现层(daoImple)----这里把dao层和实现层写在一起

package ceet.ac.cn.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import ceet.ac.cn.model.Admin;

public class AdminDao {
	 public List<Admin> getAllAdmin(){
		 	//查询所有信息
	        List<Admin> list = new ArrayList<Admin>();  //创建集合
	        Connection conn = DbHelper.getConnection();
	        String sql  = "select * from admin";  //SQL查询语句
	        try {
	            PreparedStatement pst = conn.prepareStatement(sql);
	            ResultSet rst = pst.executeQuery();
	            while (rst.next()) {
	                Admin admin = new Admin();
	                admin.setId(rst.getInt("id"));  //得到ID
	                admin.setUsername(rst.getString("username"));
	                admin.setUserpwd(rst.getString("userpwd"));
	                list.add(admin);
	            }
	            rst.close();  //关闭
	            pst.close();  //关闭
	        } catch (SQLException e) {
	            e.printStackTrace();  //抛出异常
	        }
	        return list;  //返回一个集合
	    }
	 	//添加信息
	    public boolean addAdmin(Admin admin){  
	        String sql = "INSERT INTO `admin`(`id`,`username`,`userpwd`) VALUES (?,?,?)";  //添加的SQL语句
	        Connection conn = DbHelper.getConnection();
	        try {
	            PreparedStatement pst = conn.prepareStatement(sql);
	            pst.setInt(1, admin.getId());
	            pst.setString(2, admin.getUsername());
	            pst.setString(3, admin.getUserpwd());
	            int count = pst.executeUpdate();
	            pst.close();
	            return count>0?true:false;  //是否添加的判断
	        } catch (SQLException e) {
	            e.printStackTrace();
	        }
	        return false;
	    }
	    //修改
	    public boolean updateAdmin(Admin admin){ 
	        String sql = "UPDATE `admin` SET `username`=?,`userpwd`=? WHERE `id` = ?";  //修改的SQL语句,根据ID修改
	        Connection conn = DbHelper.getConnection();
	        try {
	            PreparedStatement pst = conn.prepareStatement(sql);
	            pst.setString(1, admin.getUsername());
	            pst.setString(2, admin.getUserpwd());
	            pst.setInt(3, admin.getId());  //根据的ID
	            int count = pst.executeUpdate();
	            pst.close();  //关闭
	            return count>0?true:false;  //是否修改的判断
	        } catch (SQLException e) {
	            e.printStackTrace();
	        }
	        return false;
	    }
	    //删除
	    public boolean deleteAdmin(int id){
	        String sql = "delete from admin where id = ?";  //删除的SQL语句,根据ID删除
	        Connection conn = DbHelper.getConnection();
	        try {
	            PreparedStatement pst = conn.prepareStatement(sql);
	            pst.setInt(1, id);
	            int count = pst.executeUpdate();
	            pst.close();
	            return count>0?true:false;  //是否删除的判断
	        } catch (SQLException e) {
	            e.printStackTrace();
	        }
	        return false;
	    }
	    //根据ID进行查询
	    public Admin selectAdminById(int id){
	        Connection conn = DbHelper.getConnection();
	        String sql  = "select * from admin where id = "+id;
	        Admin admin = null;
	        try {
	            PreparedStatement pst = conn.prepareStatement(sql);
	            ResultSet rst = pst.executeQuery();
	            while (rst.next()) {
	                admin = new Admin();
	                admin.setId(rst.getInt("id"));
	                admin.setUsername(rst.getString("username"));
	                admin.setUserpwd(rst.getString("userpwd"));
	            }
	            rst.close();
	            pst.close();
	        } catch (SQLException e) {
	            e.printStackTrace();
	        }
	        return admin;  //返回
	    }
}

4:建立servlet作为控制层

    a:建立添加数据的servlet控制层

package ceet.ac.cn.servlet;

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

import ceet.ac.cn.dao.AdminDao;
import ceet.ac.cn.model.Admin;

@WebServlet("/AddServlet")
public class AddServlet extends HttpServlet {
	 //添加数据
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        this.doPost(req, resp);
    }

    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        String username = req.getParameter("username");
        String userpwd = req.getParameter("userpwd");
        Admin admin = new Admin();
        //转值,中文需要转换为utf-8
        admin.setUsername(new String(username.getBytes("ISO-8859-1"),"UTF-8"));
        admin.setUserpwd(new String(userpwd.getBytes("ISO-8859-1"),"UTF-8"));
        AdminDao dao = new AdminDao();
        dao.addAdmin(admin);
        req.getRequestDispatcher("ShowServlet").forward(req, resp);
    }
}

    b:建立删除数据servlet控制层

package ceet.ac.cn.servlet;

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

import ceet.ac.cn.dao.AdminDao;

/**
 * Servlet implementation class DeleteServlet
 */
@WebServlet("/DeleteServlet")
public class DeleteServlet extends HttpServlet {
	//删除数据
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        this.doPost(req, resp);
    }

    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        String idStr = req.getParameter("id");  //删除数据的ID,根据ID删除
        if(idStr != null && !idStr.equals("")){
            int id = Integer.valueOf(idStr);
            AdminDao dao = new AdminDao();
            dao.deleteAdmin(id);
        }
        req.getRequestDispatcher("ShowServlet").forward(req, resp);
    }
}

    c:建立查询所有数据servlet控制层

package ceet.ac.cn.servlet;

import java.io.IOException;
import java.util.List;

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

import ceet.ac.cn.dao.AdminDao;
import ceet.ac.cn.model.Admin;

/**
 * Servlet implementation class ShowServlet
 */
@WebServlet("/ShowServlet")
public class ShowServlet extends HttpServlet {
	//显示全部数据

    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        this.doPost(req, resp);
    }

    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        AdminDao dao = new AdminDao();
        List<Admin> list = dao.getAllAdmin();
        req.setAttribute("list", list);
        req.getRequestDispatcher("index.jsp").forward(req, resp);
    }
}

    d:建立修改数据servlet控制层

package ceet.ac.cn.servlet;

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

import ceet.ac.cn.dao.AdminDao;
import ceet.ac.cn.model.Admin;

/**
 * Servlet implementation class UpdateServlet
 */
@WebServlet("/UpdateServlet")
public class UpdateServlet extends HttpServlet {
	//修改
    private static final long serialVersionUID = 1L;
    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {  
    	//查询到选中ID的值所对应的数据
        String idStr = req.getParameter("id");
        if(idStr != null && !idStr.equals("")){
            int id = Integer.valueOf(idStr);
            AdminDao dao = new AdminDao();
            Admin admin = dao.selectAdminById(id);
            req.setAttribute("admin", admin);
        }
        req.getRequestDispatcher("update.jsp").forward(req, resp);
    }
    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {  //根据此ID对数据的值进行修改
        String username = req.getParameter("username");
        String userpwd = req.getParameter("userpwd");
        String idStr = req.getParameter("id");
        Admin admin = new Admin();
        admin.setId(Integer.valueOf(idStr));
        admin.setUsername(new String(username.getBytes("ISO-8859-1"),"UTF-8"));
        admin.setUserpwd(new String(userpwd.getBytes("ISO-8859-1"),"UTF-8"));
        AdminDao dao = new AdminDao();
        dao.updateAdmin(admin);
        req.getRequestDispatcher("ShowServlet").forward(req, resp);
    }
}

    5:建立jsp页面

index.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>显示</title>
    <style type="text/css">
            table {
                border: 1px solid pink;
                margin: 0 auto;
            }

            td{
                width: 150px;
                border: 1px solid pink;
                text-align: center;
            }
    </style>
</head>
<body>
    <table>
        <tr>
            <td>编号</td>
            <td>帐号</td>
            <td>密码</td>
            <td>操作</td>
        </tr>
        <c:forEach items="${list}" var="item">
            <tr>
                <td>${item.id }</td>
                <td>${item.username }</td>
                <td>${item.userpwd }</td>
                <td><a href="DeleteServlet?id=${item.id }">删除</a>|<a href="UpdateServlet?id=${item.id }">修改</a></td>
            </tr>
        </c:forEach>
        <tr>
            <td colspan="6" style="text-align: left;"><a href="add.jsp">添加管理员</a></td>
        </tr>
    </table>
</body>
</html>

add.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>添加</title>
    <link rel="stylesheet" href="css/index.css" type="text/css" />
  </head>
  <body>
  <form action="AddServlet" method="post">
    <table border="1" class="t1">
        <tr>
            <td colspan="2s"><h1>添加管理员</h1></td>
        </tr>
        <tr>
            <td>管理员帐号:</td>
            <td><input  type="text" name="username"/></td>
        </tr>
        <tr>
            <td>管理员密码:</td>
            <td><input  type="password" name="userpwd"/></td>
        </tr>
        <tr>
            <td colspan="2">
                <input  type="submit" value="提交"/>
                <input  type="reset" value="清空"/>
            </td>
        </tr>
    </table> 
   </form>
  </body>
</html>

updata.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>修改</title>
    <link rel="stylesheet" href="css/index.css" type="text/css" />
  </head>

  <body>
    <form action="UpdateServlet" method="post">
    <table border="1" class="t1">
        <tr>
            <td colspan="2"><h1>修改管理员信息</h1></td>
        </tr>
        <tr>
            <td>编号:</td>
            <td><input  type="text" name="id" value="${admin.id}" readonly="readonly"/></td>
        </tr>

        <tr>
            <td>管理员帐号:</td>
            <td><input  type="text" name="username" value="${admin.username}"/></td>
        </tr>
        <tr>
            <td>管理员密码:</td>
            <td><input  type="text" name="userpwd" value="${admin.userpwd}"/></td>
        </tr>
        <tr>
            <td colspan="2">
                <input  type="submit" value="提交"/>
                <input  type="button" value="返回" onclick="history.go(-1)"/>
            </td>
        </tr>
    </table>
   </form>
  </body>
</html>

css代码部分:

@CHARSET "UTF-8";
        table.t1 {
            margin-top:10px;
            margin-left:20px;
            margin-right:20px;
            margin-bottom:5px;
            #background-color: #FFF;
            #background:#EEF4F9;
            #border: none;
            border: 1;
            #color:#003755;
            border-collapse:collapse;
            font: 14px  "宋体";
            text-align: center;
        }

        table.t1 th{
                background:#7CB8E2;
                color:#fff;
                padding:6px 4px;
                text-align:center;
        }

        table.t1 td{
                background:#C7DDEE none repeat-x scroll center left;
                color:#000;
                padding:4px 2px;
        }

        table.t1 a{
                text-decoration:none;
                height:1em;
        }

        table.t1 a:link, table.t1  a:visited{
                color:#3366CC;
        }

        table.t1  a:hover{
                color:#B50000;
                text-decoration:underline;
        }

增删改查成果图:

添加操作:

添加后显示:

然后进行删除跟修改。

南京java,前端,Android,iOS,UI,项目经理,产品经理---招聘群:450554129

© 著作权归作者所有

小橙子的曼曼
粉丝 4
博文 89
码字总数 98903
作品 0
南京
程序员
私信 提问
【MyBiatis框架】Jdbc的弊端探讨和MyBiatis框架的简介

我们使用JSP+Servlet做Web应用的时候经常使用JDBC作为数据库的连接,那么,直接使用JDBC操作数据库进行增删改查是有一定弊端的,正因为如此才衍生出了Hibernate、MyBatis等一系列优秀的ORM框...

Mysoft
2015/09/09
115
0
ArrayList 和 CopyOnWriteArrayList

这篇文章的目的如下: 了解一下ArrayList和CopyOnWriteArrayList的增删改查实现原理 看看为什么说ArrayList查询快而增删慢? CopyOnWriteArrayList为什么并发安全且性能比Vector好 1. List接...

群星纪元
04/01
11
0
JSP+Servlet实现在JSP显示excel(不用插件)如何实现?

最近有个需求,从后台oracle数据库中查询一堆数据,因为这些数据本来就是从excel读出来关键的存在数据库的,现在要提取出来一部分展示在JSP页面上,还是以excel的样式! 需求不能使用grid显示...

蜡笔小新_
2014/06/04
439
7
.NET.Core.Entity框架

.NET.Core.Entity框架能够方便的对数据进行添加、删除、修改、查询操作(包括简单的增删改查、相同实体间的增删改查、不同实体间的增删改查操作)功能强大,容易使用。 简单的增删改查需要创...

xiao-lai
2016/06/12
3K
1
工作几年只会增删改查怎么了,大神们都是从第一行代码开始的

昨晚12点,Mike收到了一位童鞋私信,大家聊到了许久。 经过交流,了解到他大学学的是计算机系,毕业之后进入外包公司,目前已工作两年了,工作内容主要是增删改查,每天有做不完的项目,经常...

mikechen优知
09/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

x002-语言元素

变量命令规则 硬性规则: 变量名由字母(广义的Unicode字符,不包括特殊字符)、数字和下划线构成,数字不能开头。 大小写敏感(大写的a和小写的A是两个不同的变量)。 不要跟关键字(有特殊...

伟大源于勇敢的开始
今天
4
0
nginx反向代理配置

nginx配置文件位置/usr/local/nginx/conf/nginx.conf 配置文件修改: # cd /usr/local/nginx/conf # vim nginx.conf server {listen 80;server_name localhost;#charset k......

行者终成事
今天
5
0
OSChina 周日乱弹 —— 这是假的,和我之前的不一样

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 小小编辑推荐:《男孩》-梁博 / 陶孟童 / 肖和东 / 高誉容 《男孩》-梁博 / 陶孟童 / 肖和东 / 高誉容 手机党少年们想听歌,请使劲儿戳(这里...

小小编辑
今天
15
1
Rust学习笔记一 数据类型

写在前面 我也不是什么特别厉害的大牛,学历也很低,只是对一些新语言比较感兴趣,接触过的语言不算多也不算少,大部分也都浅尝辄止,所以理解上可能会有一些偏差。 自学了Java、Kotlin、Python、...

MusiCodeXY
今天
5
0
Java 脚本引擎入门

Java Script Engine Java 脚本引擎可以将脚本嵌入Java代码中,可以自定义和扩展Java应用程序,自JDK1.6被引入,基于Rhino引擎,JDK1.8后使用Nashorn引擎,支持ECMAScript 5,但后期还可能会换...

阿提说说
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部