zoukankan      html  css  js  c++  java
  • JavaWeb——库存管理系统(2).java部分---18.12.13

    DBUtil.java

    package com.hjf.util;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    /**
     * 数据库连接工具
     * @author Hu
     *
     */
    public class DBUtil {
     public static String db_url = "jdbc:mysql://localhost:3306/test?&useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC";
     public static String db_user = "root";
     public static String db_pass = "root";
     
     public static Connection getConn () {
      Connection conn = null;
      
      try {
       Class.forName("com.mysql.cj.jdbc.Driver");//连接数据库
       conn = DriverManager.getConnection(db_url, db_user, db_pass);
      } catch (Exception e) {
       e.printStackTrace();
      }
      
      return conn;
     }
     
     /**
      * 关闭连接
      * @param state
      * @param conn
      */
     public static void close (Statement state, Connection conn) {
      if (state != null) {
       try {
        state.close();
       } catch (SQLException e) {
        e.printStackTrace();
       }
      }
      
      if (conn != null) {
       try {
        conn.close();
       } catch (SQLException e) {
        e.printStackTrace();
       }
      }
     }
     
     public static void close (ResultSet rs, Statement state, Connection conn) {
      if (rs != null) {
       try {
        rs.close();
       } catch (SQLException e) {
        e.printStackTrace();
       }
      }
      
      if (state != null) {
       try {
        state.close();
       } catch (SQLException e) {
        e.printStackTrace();
       }
      }
      
      if (conn != null) {
       try {
        conn.close();
       } catch (SQLException e) {
        e.printStackTrace();
       }
      }
     }
    }
     
    CourseServlet.java
     
    package com.hjf.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 com.hjf.entity.Course;
    import com.hjf.service.CourseService;
    @WebServlet("/CourseServlet")
    public class CourseServlet extends HttpServlet {
     
     private static final long serialVersionUID = 1L;
     CourseService service = new CourseService();
     
     /**
      * 方法选择
      */
     protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
      req.setCharacterEncoding("utf-8");
      String method = req.getParameter("method");
      if ("add".equals(method)) {
       add(req, resp);
      } else if ("del".equals(method)) {
       del(req, resp);
      } else if ("update".equals(method)) {
       update(req, resp);
      } else if ("search".equals(method)) {
       search(req, resp);
      } else if ("getcoursebyid".equals(method)) {
       getCourseById(req, resp);
      } else if ("getcoursebyname".equals(method)) {
       getCourseByName(req, resp);
      } else if ("list".equals(method)) {
       list(req, resp);
      }
     }
     /**
      * 添加
      * @param req
      * @param resp
      * @throws IOException
      * @throws ServletException
      */
     private void add(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException {
      req.setCharacterEncoding("utf-8");
      String name = req.getParameter("name");
      String place = req.getParameter("place");
      String guige = req.getParameter("guige");
      String number = req.getParameter("number");
      Course course = new Course(name, place, guige,number);
      
      //添加后消息提示
      if(service.add(course)) {
       req.setAttribute("message", "添加成功");
       req.getRequestDispatcher("add.jsp").forward(req,resp);
      } else {
       req.setAttribute("message", "物资名称重复,请重新录入");
       req.getRequestDispatcher("add.jsp").forward(req,resp);
      }
     }
     
     /**
      * 全部
      * @param req
      * @param resp
      * @throws ServletException
      */
     private void list(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
      req.setCharacterEncoding("utf-8");
      List<Course> courses = service.list();
      req.setAttribute("courses", courses);
      req.getRequestDispatcher("list.jsp").forward(req,resp);
     }
     /**
      * 通过ID得到Course
      * @param req
      * @param resp
      * @throws ServletException
      */
     private void getCourseById(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
      req.setCharacterEncoding("utf-8");
      int id = Integer.parseInt(req.getParameter("id"));
      Course course = service.getCourseById(id);
      req.setAttribute("course", course);
      req.getRequestDispatcher("detail2.jsp").forward(req,resp);
     }
     /**
      * 通过名字查找 
      * 跳转至删除
      * @param req
      * @param resp
      * @throws IOException
      * @throws ServletException
      */
     private void getCourseByName(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
      req.setCharacterEncoding("utf-8");
      String name = req.getParameter("name");
      Course course = service.getCourseByName(name);
      if(course == null) {
       req.setAttribute("message", "查无此物资");
       req.getRequestDispatcher("del.jsp").forward(req,resp);
      } else {
       req.setAttribute("course", course);
       req.getRequestDispatcher("detail.jsp").forward(req,resp);
      }
     }
     
     /**
      * 删除
      * @param req
      * @param resp
      * @throws IOException
      * @throws ServletException
      */
     private void del(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
      req.setCharacterEncoding("utf-8");
      int id = Integer.parseInt(req.getParameter("id"));
      service.del(id);
      req.setAttribute("message", "删除成功");
      req.getRequestDispatcher("del.jsp").forward(req,resp);
     }
     
     /**
      * 修改
      * @param req
      * @param resp
      * @throws IOException
      * @throws ServletException
      */
     private void update(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
      req.setCharacterEncoding("utf-8");
      int id = Integer.parseInt(req.getParameter("id"));
      String name = req.getParameter("name");
      String place = req.getParameter("place");
      String guige = req.getParameter("guige");
      String number = req.getParameter("number");
      Course course = new Course(id, name, place, guige,number);
      
      service.update(course);
      req.setAttribute("message", "修改成功");
      req.getRequestDispatcher("CourseServlet?method=list").forward(req,resp);
     }
     
     /**
      * 查找
      * @param req
      * @param resp
      * @throws ServletException
      */
     private void search(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
      req.setCharacterEncoding("utf-8");
      String name = req.getParameter("name");
      String place = req.getParameter("place");
      String guige = req.getParameter("guige");
      String number = req.getParameter("number");
      List<Course> courses = service.search(name, place, guige,number);
      req.setAttribute("courses", courses);
      req.getRequestDispatcher("searchlist.jsp").forward(req,resp);
     }
    }
     
    CourseService.java
     
    package com.hjf.service;
    import java.util.List;
    import com.hjf.dao.CourseDao;
    import com.hjf.entity.Course;
    /**
     * CourseService
     * 服务层
     * @author Hu
     *
     */
    public class CourseService {
     CourseDao cDao = new CourseDao();
     
     /**
      * 添加
      * @param course
      * @return
      */
     public boolean add(Course course) {
      boolean f = false;
      if(!cDao.name(course.getName())) {
       cDao.add(course);
       f = true;
      }
      return f;
     }
     
     /**
      * 删除
      */
     public void del(int id) {
      cDao.delete(id);
     }
     
     /**
      * 修改
      * @return
      */
     public void update(Course course) {
      cDao.update(course);
     }
     
     /**
      * 通过ID得到一个Course
      * @return
      */
     public Course getCourseById(int id) {
      return cDao.getCourseById(id);
     }
     /**
      * 通过name得到一个Course
      * @return
      */
     public Course getCourseByName(String name) {
      return cDao.getCourseByName(name);
     }
     
     /**
      * 查找
      * @return
      */
     public List<Course> search(String name, String place, String guige,String number) {
      return cDao.search(name, place, guige,number);
     }
     
     /**
      * 全部数据
      * @return
      */
     public List<Course> list() {
      return cDao.list();
     }
    }
     
    Course.java
     
    package com.hjf.entity;
    public class Course {
     private int id;
     private String name;
     private String place;
     private String guige;
     private String number;
     public int getId()
     {
      return id;
     }
     public void setId(int id)
     {
      this.id = id;
     }
     public String getName()
     {
      return name;
     }
     public void setName(String name)
     {
      this.name = name;
     }
     public String getPlace()
     {
      return place;
     }
     public void setPlace(String place)
     {
      this.place = place;
     }
     public String getGuige()
     {
      return guige;
     }
     public void setGuige(String guige)
     {
      this.guige = guige;
     }
     public String getNumber()
     {
      return number;
     }
     public void setNumber(String number)
     {
      this.number = number;
     }
     public Course() {}
     
     public Course(int id, String name, String teacher, String classroom,String number) {
      this.id = id;
      this.name = name;
      this.place = place;
      this.guige = guige;
      this.number=number;
     }
     
     public Course(String name, String teacher, String classroom,String number) {
      this.name = name;
      this.place = place;
      this.guige = guige;
      this.number=number;
     }
     
     CourseDao.java
     
    package com.hjf.dao;
    import java.sql.Connection;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.util.ArrayList;
    import java.util.List;
    import com.hjf.entity.Course;
    import com.hjf.util.DBUtil;
    /**
     * 商品Dao
     * Dao层操作数据
     * @author Hu
     *
     */
    public class CourseDao {
     /**
      * 添加
      * @param course
      * @return
      */
     public boolean add(Course course) {
      String sql = "insert into course(name, place, guige,number) values('" + course.getName() + "','" + course.getPlace() + "','" + course.getGuige() + "','" + course.getNumber()+"')";
      Connection conn = DBUtil.getConn();
      Statement state = null;
      boolean f = false;
      int a = 0;
      
      try {
       state = conn.createStatement();
       state.executeUpdate(sql);
      } catch (Exception e) {
       e.printStackTrace();
      } finally {
       DBUtil.close(state, conn);
      }
      
      if (a > 0) {
       f = true;
      }
      return f;
     }
     /**
      * 删除
      *
      * @param id
      * @return
      */
     public boolean delete (int id) {
      boolean f = false;
      String sql = "delete from course where id='" + id + "'";
      Connection conn = DBUtil.getConn();
      Statement state = null;
      int a = 0;
      
      try {
       state = conn.createStatement();
       state.executeUpdate(sql);
      } catch (SQLException e) {
       e.printStackTrace();
      } finally {
       DBUtil.close(state, conn);
      }
      
      if (a > 0) {
       f = true;
      }
      return f;
     }
     /**
      * 修改
      * @param name
      * @param pass
      */
     public boolean update(Course course) {
      String sql = "update course set name='" + course.getName() + "', place='" + course.getPlace() + "', guige='" + course.getGuige()+"', number='" + course.getNumber()
       + "' where id='" + course.getId() + "'";
      Connection conn = DBUtil.getConn();
      Statement state = null;
      boolean f = false;
      int a = 0;
      try {
       state = conn.createStatement();
       a=state.executeUpdate(sql);
      } catch (SQLException e) {
       e.printStackTrace();
      } finally {
       DBUtil.close(state, conn);
      }
      
      if (a > 0) {
       f = true;
      }
      return f;
     }
     
     /**
      * 验证课程名称是否唯一
      * true --- 不唯一
      * @param name
      * @return
      */
     public boolean name(String name) {
      boolean flag = false;
      String sql = "select name from course where name = '" + name + "'";
      Connection conn = DBUtil.getConn();
      Statement state = null;
      ResultSet rs = null;
      
      try {
       state = conn.createStatement();
       rs = state.executeQuery(sql);
       while (rs.next()) {
        flag = true;
       }
      } catch (SQLException e) {
       e.printStackTrace();
      } finally {
       DBUtil.close(rs, state, conn);
      }
      return flag;
     }
     
     /**
      * 通过ID得到类
      * @param id
      * @return
      */
     public Course getCourseById(int id) {
      String sql = "select * from course where id ='" + id + "'";
      Connection conn = DBUtil.getConn();
      Statement state = null;
      ResultSet rs = null;
      Course course = null;
      
      try {
       state = conn.createStatement();
       rs = state.executeQuery(sql);
       while (rs.next()) {
        String name = rs.getString("name");
        String place = rs.getString("place");
        String guige = rs.getString("guige");
        String number = rs.getString("number");
        course = new Course(id, name, place,guige,number);
       }
      } catch (Exception e) {
       e.printStackTrace();
      } finally {
       DBUtil.close(rs, state, conn);
      }
      
      return course;
     }
     
     /**
      * 通过name得到Course
      * @param name
      * @return
      */
     public Course getCourseByName(String name) {
      String sql = "select * from course where name ='" + name + "'";
      Connection conn = DBUtil.getConn();
      Statement state = null;
      ResultSet rs = null;
      Course course = null;
      
      try {
       state = conn.createStatement();
       rs = state.executeQuery(sql);
       while (rs.next()) {
        int id = rs.getInt("id");
        String place = rs.getString("place");
        String guige = rs.getString("guige");
        String number = rs.getString("number");
        course = new Course(id, name, place, guige,number);
       }
      } catch (Exception e) {
       e.printStackTrace();
      } finally {
       DBUtil.close(rs, state, conn);
      }
      
      return course;
     }
     
     /**
      * 查找
      * @param name
      * @param place
      * @param guige
      * @param number
      * @return
      */
     public List<Course> search(String name, String place, String guige,String number) {
      String sql = "select * from course where ";
      if (name != "") {
       sql += "name like '%" + name + "%'";
      }
      if (place != "") {
       sql += "place like '%" + place + "%'";
      }
      if (guige != "") {
       sql += "guige like '%" + guige + "%'";
      }
      if (number != "") {
       sql += "name like '%" + number + "%'";
      }
      List<Course> list = new ArrayList<>();
      Connection conn = DBUtil.getConn();
      Statement state = null;
      ResultSet rs = null;
      try {
       state = conn.createStatement();
       rs = state.executeQuery(sql);
       Course bean = null;
       while (rs.next()) {
        int id = rs.getInt("id");
        String name2 = rs.getString("name");
        String place2 = rs.getString("place");
        String guige2 = rs.getString("guige");
        String number2 = rs.getString("number2");
        bean = new Course(id, name2, place2, guige2,number2);
        list.add(bean);
       }
      } catch (SQLException e) {
       e.printStackTrace();
      } finally {
       DBUtil.close(rs, state, conn);
      }
      
      return list;
     }
     
     /**
      * 全部数据
      * @param name
      * @param place
      * @param guige
      * @return
      */
     public List<Course> list() {
      String sql = "select * from course";
      List<Course> list = new ArrayList<>();
      Connection conn = DBUtil.getConn();
      Statement state = null;
      ResultSet rs = null;
      try {
       state = conn.createStatement();
       rs = state.executeQuery(sql);
       Course bean = null;
       while (rs.next()) {
        int id = rs.getInt("id");
        String name2 = rs.getString("name");
        String place2 = rs.getString("place");
        String guige2 = rs.getString("guige");
        String number2 = rs.getString("number2");
        bean = new Course(id, name2, place2, guige2,number2);
        list.add(bean);
       }
      } catch (SQLException e) {
       e.printStackTrace();
      } finally {
       DBUtil.close(rs, state, conn);
      }
      
      return list;
     }
    }
     
    OK,以上就是java部分
    总的来说,现在完成这个所要求的功能还是蛮快的。
     
  • 相关阅读:
    MongoDB
    Redis:C#使用Redis
    最大化 AIX 上的 Java 性能,第 4 部分: 监视流量
    最大化 AIX 上的 Java 性能,第 3 部分: 更多就是更好
    最大化 AIX 上的 Java 性能,第 2 部分: 速度需求
    最大化 AIX 上的 Java 性能,第 1 部分: 基础
    阿里面试重点总结
    函数库学习入门指引
    OracleAWR删除历史快照说明
    ActiveMQ实现负载均衡+高可用部署方案(转)
  • 原文地址:https://www.cnblogs.com/mitang0-0/p/10308299.html
Copyright © 2011-2022 走看看