• 2020年12月4日Java学习日记


    通过前面的练习发现自己对于增删改查的知识仍然不够熟练,今天进行一个基于课程管理的增删改查功能的实现。

    Dbutil:

    复制代码
    复制代码
    package com.zh.util;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.Statement;
    import java.sql.SQLException;
    
    public class DButil {
        public static Connection getConnection(){
            Connection conn = null;
            try {
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
            String url="jdbc:mysql://localhost:3306/teacher_class?serverTimezone=UTC";
            conn=DriverManager.getConnection(url, "root", "hao19990507.");
            }catch (Exception e){
                e.printStackTrace();
            }
            return conn;
        }
        
        public static void close(Statement sta,Connection con){
            if (sta != null) {
                try {
                    sta.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
            if (con != null) {
                try {
                    con.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
        public static void close(ResultSet rs,Statement sta,Connection con){
            if (rs != null) {
                try {
                    rs.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
            if (sta != null) {
                try {
                    sta.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
            if (con != null) {
                try {
                    con.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
    复制代码
    复制代码

    bean:

    复制代码
    复制代码
    package com.zh.entity;
    
    
    
        public class bean {
        private String place;
        private String teacher_name;
        private String class_name;
        public String get_place() {
            return place;
        }
        public void set_place(String place) {
            this.place=place;
        }
        public String get_teacher_name() {
            return teacher_name;
        }
        public void set_teacher_name(String teacher_name) {
            this.teacher_name=teacher_name;
        }
        public String get_class_name() {
            return class_name;
        }
        public void set_class_name(String class_name) {
            this.class_name=class_name;
        }
        public bean() {};
        
        public bean(String place,String teacher_name,String class_name) {
            this.place=place;
            this.teacher_name=teacher_name;
            this.class_name=class_name;
            }
    }
    复制代码
    复制代码

    data_dao:

    复制代码
    复制代码
    package com.zh.dao;
    import java.util.*;
    import java.sql.*;
    import com.zh.entity.*;
    import com.zh.util.*;
    import java.sql.*;
    public class data_dao {
        /*增加
         * 
         */
    public void add(bean Bean) {
        String sql="insert into class_message values('"+Bean.get_place()+"','"+Bean.get_teacher_name()+"','"+Bean.get_class_name()+"')";
        Connection conn = DButil.getConnection();
        Statement state = null;
        try {
            state = conn.createStatement();
            state.executeUpdate(sql);
        } catch (Exception e) {
            e.printStackTrace();
        } 
    }
    /*删除
     * 
     */
    public void deleteByteacher_name(String teacher_name) {
        boolean f=false;
        String sql="delete from class_message where teacher_name='"+teacher_name+"'";
        Connection conn=DButil.getConnection();
        Statement state = null;
        
        try {
            
            state = conn.createStatement();
            state.executeUpdate(sql);
        } catch (SQLException e) {
            e.printStackTrace();
        } 
        
        }
             /* 修改
             * 
             */
    
    public void updata(bean b) {
        String sql="updata class_message set place='"+b.get_place()+"', teacher_name='"+b.get_teacher_name()+"',class_name='"+b.get_class_name()+"' where teacher_name='"+b.get_teacher_name()+"'";
        
        Connection conn=DButil.getConnection();
        Statement state = null;
        try {
            state = conn.createStatement();
            state.executeUpdate(sql);
        } catch (SQLException e) {
            e.printStackTrace();
        } 
        
    
    }
    /**
     * 验证课程名称是否唯一
     */
    public List<bean> isOnly_class_name(String class_name) {
        List list=new ArrayList<bean>();
        String sql="select name from class_message where class_name='"+class_name+"'";
        Connection conn=DButil.getConnection();
        Statement state=null;
        ResultSet rs = null;
        try {
            state = conn.createStatement();
            rs = state.executeQuery(sql);
            while(rs.next()) {
                String class_name1=rs.getString("class_name");
                String teacher_name=rs.getString("teacher_name");
                String place=rs.getString("place");
                bean b=new bean(place,teacher_name,class_name1);
                list.add(b);
            }
        } catch (SQLException e) {
        e.printStackTrace();
    }
        return list;
    }
    
                                                                                                                                                                                                                                                                           
    /**
     * 通过teacher_name获得一个bean对象
     */
    public bean findByteacher_name(String teacher_name) {
            Connection conn=null;
        Statement state=null;
        
        try {
            conn=DButil.getConnection();
            String sql="select*from class_message where teacher_name='"+teacher_name+"'";
            
            state=conn.createStatement();
            ResultSet rs=state.executeQuery(sql);
            bean u=new bean();;
            while(rs.next()) {
                String t_name=rs.getString("teacher_name");
                String c_name=rs.getString("class_name");
                String place=rs.getString("place");
                u.set_class_name(c_name);
                u.set_place(place);
                u.set_teacher_name(t_name);
                return u;
            }
        }catch (Exception e) {
            e.printStackTrace();
            }
    
    return null;
    }
    /*
     * 显示全部
     */
    public List<bean> findAll(){
        Connection conn=DButil.getConnection();
        List<bean> list=new ArrayList<bean>();
        bean b=null;
        try {
        Statement sta=conn.createStatement();
        String sql="select * from class_message";
        ResultSet rs=sta.executeQuery(sql);
            while(rs.next()) {
                b=new bean();
                String t_name,c_name,place;
                t_name=rs.getString("teacher_name");
                c_name=rs.getString("c_name");
                place=rs.getString("place");
                b.set_class_name(c_name);
                b.set_place(place);
                b.set_teacher_name(t_name);
                list.add(b);
            }
        }catch (Exception e) {
            e.printStackTrace();
        }
        for(int i=0;i<list.size();i++) {
            bean br=(bean)list.get(i);
            System.out.println(br.get_teacher_name());
        }
        return list;
    }
    }
    复制代码
    复制代码

    Userservice:

    复制代码
    复制代码
    package com.zh.service;
    import java.util.*;
    import com.zh.dao.*;
    import com.zh.entity.*;
    public class Userservice {
    public boolean insertUser(String place,String teacher_name,String class_name) {
        data_dao dao=new data_dao();
        bean b=new bean();
        b.set_class_name(class_name);
        b.set_place(place);
        b.set_teacher_name(teacher_name);
        try {
        dao.add(b);
        return true;
        }catch (Exception e) {
            e.printStackTrace();
            return false;
        }
    }
    public boolean deleteUser(String teacher_name) {
        data_dao dao=new data_dao();
        bean b=dao.findByteacher_name(teacher_name);
        if(b!=null) {
            dao.deleteByteacher_name(teacher_name);
            return true;
        }else 
            return false;
    }
    public boolean updataByteacher_name(String place,String class_name,String teacher_name) {
        data_dao dao=new data_dao();
        bean b=new bean(place,class_name,teacher_name);
        try {
            dao.updata(b);
            return true;
        }catch (Exception e) {
            e.printStackTrace();
            return false;
        }
        }
    public boolean isOnly_classname(String class_name) {
        data_dao dao=new data_dao();
        try {
            List list=dao.isOnly_class_name(class_name);
            if(list.size()>1)
                return true;
            else
                return false;
        }catch (Exception e) {
            e.printStackTrace();
            return false;
        }
    }
    
    public List<bean> findAll_user(){
        data_dao dao=new data_dao();
        List list=dao.findAll();
        return list;
    }
    }
    复制代码
    复制代码

    DeleteServlet:

    复制代码
    复制代码
    package com.zh.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 com.zh.service.*;
    @WebServlet("/DeleteServlet")
    public class DeleteServlet extends HttpServlet {
        
           protected void service(HttpServletRequest arg0,HttpServletResponse arg1) 
                   throws ServletException ,IOException{
               arg1.setContentType("text/html");
               arg0.setCharacterEncoding("GBK");
               arg1.setCharacterEncoding("GBK");
               String name=arg0.getParameter("teacher_name");
               Userservice service =new Userservice();
               service.deleteUser(name);
               try {
                   arg0.getRequestDispatcher("/query").forward(arg0, arg1);
               }catch (Exception e) {
                   e.printStackTrace();
               }
           }
        
       }
    复制代码
    复制代码

    InsertServlet:

    复制代码
    复制代码
    package com.zh.servlet;
    
    import java.io.IOException;
    import java.io.PrintWriter;
    
    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.zh.service.*;
    @WebServlet("/InsertServlet")
    public class InsertServlet extends HttpServlet {
        protected void service(HttpServletRequest req,HttpServletResponse res) 
                throws ServletException,IOException {
            res.setContentType("text/html");
            req.setCharacterEncoding("GBK");
            res.setCharacterEncoding("GBK");
            String place=req.getParameter("place");
            String teacher_name=req.getParameter("teacher_name");
            String class_name=req.getParameter("class_name");
            PrintWriter pw=res.getWriter();
            Userservice service=new Userservice();
            try {
                service.insertUser(place, teacher_name, class_name);
                pw.println("新增信息成功!");
                req.getRequestDispatcher("/query").forward(req, res);;
            }catch (Exception e) {
                e.printStackTrace();
                req.getRequestDispatcher("/insert.html").forward(req, res);
            }
        }
    
        
        
    
    }
    复制代码
    复制代码

    QueryServlet:

    复制代码
    复制代码
    package com.zh.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 java.io.PrintWriter;
    import com.zh.entity.*;
    import com.zh.service.*;
    import java.util.*;
    @WebServlet("/QueryServlet")
    public class QueryServlet extends HttpServlet {
        protected void service(HttpServletRequest req,HttpServletResponse res) 
                throws ServletException,IOException {
            res.setContentType("text/html");
            req.setCharacterEncoding("GBK");
            res.setCharacterEncoding("GBK");
            PrintWriter pw=res.getWriter();
            Userservice service=new Userservice();
            List list=service.findAll_user();
            pw.println("<html>");
            pw.println("<head>");
            pw.println("</head>");
            pw.println("<body>");
            pw.println("<table border='1' bordercolor='red' align='center'");
            pw.println("<tr>");
            pw.println("<td>");
            pw.println("地点");
            pw.println("</td>");
            pw.println("<td>");
            pw.println("教师名");
            pw.println("</td>");
            pw.println("<td>");
            pw.println("课程名");
            pw.println("</td>");
            pw.println("</tr>");
            for(int i=0;i<list.size();i++) {
            bean b=(bean) list.get(i);
            pw.println("<tr>");
            pw.println("<td>");
            pw.println(b.get_place());
            pw.println("</td>");
            pw.println("<td>");
            pw.println(b.get_teacher_name());
            pw.println("</td>");
            pw.println("<td>");
            pw.println(b.get_class_name());
            pw.println("/<td>");
            pw.println("<a href='/Web_operation1/delete?teacher_name="+b.get_teacher_name()+"'> 删 除   </a>||<a href='/Web_operation1/updata.html'>修改信息</a>" );
                    pw.println("</td>");
                    pw.println("</tr>");
            }
            pw.println("</table>");
            pw.println("</body>");
            pw.println("</html>");
            pw.flush();
            pw.close();
    }
    }
    复制代码
    复制代码

    UpdateServlet:

    复制代码
    复制代码
    package com.zh.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 java.io.PrintWriter;
    import com.zh.service.*;
    
    @WebServlet("/UpdataServlet")
    public class UpdateServlet extends HttpServlet {
    protected void service(HttpServletRequest req,HttpServletResponse res) 
            throws ServletException,IOException {
        res.setContentType("text/html");
        req.setCharacterEncoding("GBK");
        res.setCharacterEncoding("GBK");
        PrintWriter pw=res.getWriter();
        Userservice service=new Userservice();
        String place=req.getParameter("place");
        String teacher_name=req.getParameter("teacher_name");
        String class_name=req.getParameter("class_name");
        try {
            if (service.updataByteacher_name(place, class_name, teacher_name)) {
                res.sendRedirect("/Web_operation1/query");
            }
        }catch (Exception e) {
            e.printStackTrace();
        }
    }
    }
    复制代码
    复制代码

    insert.html:

    复制代码
    复制代码
    <!DOCTYPE HTML PUBLIC"-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <meta charset="UTF-8">
    <title>Insert </title>
    </head>
    <body>
    <center>
    <form action="/Web_operation1/insert"medthod="post">
       <table border ="1" bordercolor="red"align="center">
       <tr>
       <td>
         上课地点:
         </td>
         <td>
         <input type="text" name="place"/>
         </td>
         
         </tr>
       <tr>
       <td>
       任课教师:
       </td>
       <td>
       <input type="text" name="teacher_name"/>
       </td>
       </tr>
       <tr>
       <td>
       课程名称:
       </td>
       <td>
       <input type="text" name="class_name"/>;
       </td>
       </tr>
       </table>
       </form>
       </center>              
    </body>
    </html>
    复制代码
    复制代码

    update.html:

    复制代码
    复制代码
    <!DOCTYPE HTML PUBLIC"-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <meta charset="UTF-8">
    <title>update</title>
    </head>
    <body>
    <center>
    <form action="/Web_operation1/update" method="post">
    <table border="1"bordercolor="red" align="center">
    <tr>
    <td> 上课地点:</td>
    <td>
    <input type="text" name="place">
    </td>
    </tr>
    <tr>
    <td> 任课教师:</td>
    <td>
    <input type="text" name="teacher_name">
    </td>
    </tr>
    <tr>
    <td> 课程名称:</td>
    <td>
    <input type="text"name="class_name">
    </td>
    </tr>
    <tr>
     <td colspan="2"align="center">
     <input type="button" value="确认">
     </td>
     </tr>
    </table>
    </form>
    </body>
    </html>
    复制代码
    复制代码

    web.xml:

    复制代码
    复制代码
    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0">
      <display-name>Web_operation1</display-name>
      <welcome-file-list>
        <welcome-file>index.html</welcome-file>
        <welcome-file>index.htm</welcome-file>
        <welcome-file>index.jsp</welcome-file>
        <welcome-file>default.html</welcome-file>
        <welcome-file>default.htm</welcome-file>
        <welcome-file>default.jsp</welcome-file>
      </welcome-file-list>
      <servlet>
      <servlet-name>query</servlet-name>
      <servlet-class>com.zh.servlet.QueryServlet</servlet-class>
      </servlet>
      <servlet-mapping>
      <servlet-name>query</servlet-name>
      <url-pattern>/query</url-pattern>
      </servlet-mapping>
      <servlet>
      <servlet-name>delete</servlet-name>
      <servlet-class>com.zh.servlet.DeleteServlet</servlet-class>
      </servlet>
      <servlet-mapping>
      <servlet-name>delete</servlet-name>
      <url-pattern>/delete</url-pattern>
      </servlet-mapping>
      <servlet>
      <servlet-name>update</servlet-name>
      <servlet-class>com.zh.servlet.UpdateServlet</servlet-class>
      </servlet>
      <servlet-mapping>
      <servlet-name>update</servlet-name>
      <url-pattern>/update</url-pattern>
      </servlet-mapping>
      <servlet>
      <servlet-name>insert</servlet-name>
      <servlet-class>com.zh.servlet.InsertServlet</servlet-class>
      </servlet>
      <servlet-mapping>
      <servlet-name>insert</servlet-name>
      <url-pattern>/insert</url-pattern>
      </servlet-mapping>
      
    </web-app>
  • 相关阅读:
    学习SpirngMVC之如何获取请求参数
    深入理解 CSS3 弹性盒布局模型
    JavaScript正则表达式验证大全(收集)
    我所认识的JavaScript正则表达式
    不再以讹传讹,GET和POST的真正区别
    JavaScript中的正则表达式
    Unicode 与 Unicode Transformation Format(UTF-8 / UTF-16 / UTF-32)
    PHP垃圾回收机制
    排序算法系列
    求最短路径算法系列
  • 原文地址:https://www.cnblogs.com/9635741zly/p/14176490.html
Copyright © 2020-2023  润新知