dao.java

package 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 DBUtil.Course;
import DBUtil.DBUtil;
public class dao
{
 //添加
 //@param course
 
 public boolean add(Course course)
 {
  String sql="insert into class(name,grade) values('"+course.getName()+"','"+course.getGrade()+"')";
  Connection conn=DBUtil.getConn();//数据库连接,加载驱动
  Statement state=null;//数据库操作
  
  try
  {
   state=conn.createStatement();//实例化Statement对象
   state.executeUpdate(sql);//执行数据库更新操作
  }catch(Exception e)//当try语句中出现异常时,会执行catch中的语句
    {
   e.printStackTrace();//捕获异常的语句
    }
   finally //finally作为异常处理的一部分,它只能用在try/catch语句中,并且附带一个语句块,表示这段语句最终一定会被执行(不管有没有抛出异常),经常被用在需要释放资源的情况下。
   {
    DBUtil.close(state, conn); //close释放资源
   }
  return false;
 }
 
 //删除
 //@param id
 
 public boolean delete(int id)
 {
  String sql="delete from class where id='"+id+"'";
  Connection conn=DBUtil.getConn();
  Statement state=null;
  
  try
  {
   state=conn.createStatement();
   state.executeUpdate(sql);//价格问号??为什么原版是a=state.executeUpdate(sql),而只有添加那里没有
  }catch (Exception e)
  {
   e.printStackTrace();
  }
  finally
  {
   DBUtil.close(state, conn);
  }
  return false;
 }
 
 //修改
 //@param name
 
 public boolean update(Course course)
 {
  String sql="update class set name='"+course.getName()+"',place='"+course.getGrade()+"'where id='"+course.getId()+"'";
  Connection conn=DBUtil.getConn();
  Statement state=null;
  
  try
  {
   state=conn.createStatement();
   state.executeUpdate(sql);
  }catch (SQLException e)
  {
   e.printStackTrace();
  }
  finally
  {
   DBUtil.close(state, conn);
  }
  return false;
 }
 
 /**
  * 验证人物名称是否唯一
  * true --- 不唯一
  * @param name
  * @return
  */
 public boolean name(String name) {
  boolean flag = false;
  String sql = "select name from class 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 class 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");
    int grade = rs.getInt("grade");
    course = new Course(id, name, grade);
   }
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   DBUtil.close(rs, state, conn);
  }
  
  return course;
 }
 //通过name得到Course
 //@param name
 
 public Course getCourseByName(String name)
 {
  boolean f=false;
  String sql="select name from class where name='"+name+"'";
  Connection conn=DBUtil.getConn(); //Connection是建立与数据库的链接
  Statement state=null;  //Statement算是一个连接的实例,用来执行SQL语句,
  ResultSet rs=null;  //ResultSet是查询后得到的结果集,得到结果后必须执行.next()方法
  Course course = null;
  
  try
  {
   state=conn.createStatement();
   rs=state.executeQuery(sql);
   while (rs.next()) {
    int id = rs.getInt("id");
    int grade = rs.getInt("grade");
    course = new Course(id, name,grade);
   }
  }
  catch (SQLException e)
  {
   e.printStackTrace();
  }
  finally
  {
   DBUtil.close(rs,state, conn);
  }
  return course;
 }
 
 //查找
 //@param name
 
 public List<Course>search(String name,int grade)
 {
  String sql="select * from class where";
  if (name!=" ")
  {
   sql+="name like'%"+name+"%'";
  }
  if (grade!=' ')
  {
   sql+="name like'%"+grade+"%'";
  }
  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 name1=rs.getString("name");
    int grade1=rs.getInt("grade");
    bean=new Course(id,name1,grade1);
    list.add(bean);   }
  }
  catch (SQLException e) {
   e.printStackTrace();
  } finally {
   DBUtil.close(rs, state, conn);
  }
  return list;
 }
 
 //全部数据
 
 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 name=rs.getString("name");
    int grade=rs.getInt("grade");
    bean=new Course(id,name,grade);
   }
  }
  catch (SQLException e) {
   e.printStackTrace();
  } finally {
   DBUtil.close(rs, state, conn);
  }
  
  return list;
 }
}
 
 
Course.java
 
package DBUtil;
public class Course
{
 private int id;
 private String name;
 private int grade;
 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 int getGrade()
 {
  return grade;
 }
 public void setGrade(int grade)
 {
  this.grade = grade;
 }
 public Course(int id, String name, int grade) {
  this.id = id;
  this.name = name;
  this.grade = grade;
 }
 
 public Course(String name, int grade) {
  this.name = name;
  this.grade = grade;
 }
}
 
DBUtil.java
 
package DBUtil;
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 {
 //联结字符串                                              //数据库名test
 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 () {
  
  //声明与数据库的连接并实例化为null
  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();
   }
  }
 }
}
 
servlet.java
 
package 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 DBUtil.Course;
import Dao.service;
@WebServlet("/servlet")
public class servlet extends HttpServlet
{
 private static final long serialVersionUID = 1L;
 
 service service1=new service();
 
 //方法选择
 
 protected void service(HttpServletRequest req,HttpServletResponse resp)throws ServletException, IOException
 {
  req.setCharacterEncoding("utf-8");//设置从jsp中请求道德数据的值,也就是设置为中文,防止乱码
  String method=req.getParameter("method");//getParameter()获取的是客户端设置的数据。
  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);
  }
 }
 
 //添加
 
 private void add(HttpServletRequest req,HttpServletResponse resp)throws IOException, ServletException
 {
  req.setCharacterEncoding("utf-8");
  String name=req.getParameter("name");
  int grade=Integer.parseInt(req.getParameter("grade"));
  Course course=new Course(name,grade);
  
  //添加后消息提示
  if(service1.add(course))
  {
   req.setAttribute("massage", "添加成功");
   req.getRequestDispatcher("add.jsp").forward(req, resp);
  }
  else
  {
   req.setAttribute("massage", "名称重复,请重新录入");
   req.getRequestDispatcher("add.jsp").forward(req, resp);//处理完了,分发到下一个JSP页面或者下一个Action继续处理。
  }
 }
 
 //全部
 
 private void list(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
  req.setCharacterEncoding("utf-8");
  List<Course> courses = service1.list();
  req.setAttribute("courses", courses);
  req.getRequestDispatcher("list.jsp").forward(req,resp);
 }
 
 //通过ID得到Course, 转到detail2.jsp
 
 private void getCourseById(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
  req.setCharacterEncoding("utf-8");
  int id = Integer.parseInt(req.getParameter("id"));
  Course course = service1.getCourseById(id);
  req.setAttribute("course", course);
  req.getRequestDispatcher("detail2.jsp").forward(req,resp);
 }
 
 //通过name查找Course, 转到detail1.jsp
 
 private void getCourseByName(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException{
  req.setCharacterEncoding("utf-8");
  String name = req.getParameter("name");
  Course course = service1.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);
  }
 }
 
 //删除delete
 
 private void del(HttpServletRequest req,HttpServletResponse resp)throws IOException,ServletException
 {
  req.setCharacterEncoding("UTF-8");
  int id=Integer.parseInt(req.getParameter("id"));
  service1.del(id);
  req.setAttribute("message", "删除成功");
  req.getRequestDispatcher("del.jsp").forward(req, resp);
 }
 
 //修改update
 
 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");
  int grade=Integer.parseInt(req.getParameter("grade"));
  Course course = new Course(id, name,grade);  
  service1.update(course);
  req.setAttribute("message", "修改成功");
  req.getRequestDispatcher("servlet?method=list").forward(req,resp);
     //?method=list表示传一个叫做method的参数,他的值是list,你可以在Servlet中用request.getParam...获取到。
 }
 
 //查询
 
 private void search(HttpServletRequest req,HttpServletResponse resp)throws IOException,ServletException
 {
  req.setCharacterEncoding("UTF-8");
  String name=req.getParameter("name");
  int grade=Integer.parseInt(req.getParameter("grade"));
  List<Course>courses=service1.search(name, grade);
  req.setAttribute("Course", courses);
  req.getRequestDispatcher("searchlist.jsp").forward(req, resp);
 }
}
 
结束。
这次挑战赛失败,不过没关系,一点一点地把程序骂了出来并且做了详细的注释。也算颇丰。

JavaWeb——升级赛-学生成绩管理系统(2).java---19.01.03的更多相关文章

  1. JavaWeb——升级赛-学生成绩管理系统(1)jsp---19.01.03

    add.jsp <%@ page language="java" contentType="text/html; charset=UTF-8"    pa ...

  2. Java项目:学生成绩管理系统(二)

    学生成绩管理系统(二):项目介绍 一.设计要求: 1.1 简单的图形界面登录功能. 1.2 对数据库的的信息的查询功能. 1.3 对数据库的的信息的修改功能. 1.4 对数据库的的信息的删除功能. 1 ...

  3. 学生成绩管理系统 1.0(Java+MySql)

    真难…… 数据库建立不会,中文编码不会,插入数据不会,删除不会…… Java读入数据不会……数据库连接不会…… 你也好意思说自己是学计算机的啊魂淡…… 我会慢慢写2.0,3.0版的……噗…… src/ ...

  4. 使用Java模拟一个简单的Dos学生成绩管理系统:

    使用Java模拟学生成绩管理系统... ------------------- 学生成绩管理系统:需要实现的功能:1.录入学生的姓名和成绩2.显示列表.列表中包括学生姓名与成绩3.显示最高分.最低分的 ...

  5. Java课程设计—学生成绩管理系统(201521123005 杨雪莹)

    一.团队课程设计博客链接 学生成绩管理系统 二.个人负责模块或任务说明 学生成绩录入 显示所有学生信息 显示各科平均成绩 显示学生成绩(按降序排序) 三.自己的代码提交记录截图 四.自己负责模块或任务 ...

  6. Java课程设计——学生成绩管理系统(201521123003 董美凤)

    Java课程设计--学生成绩管理系统(201521123003 董美凤) 1.团队课程设计博客链接 学生成绩管理系统博客链接 2.个人负责模块或任务说明 信息修改 密码修改 部分界面设计 3.自己的代 ...

  7. Java开学测试-学生成绩管理系统

    题目: 1.定义 ScoreInformation 类,其中包括七个私有变量(stunumber, name, mathematicsscore, englishiscore,networkscore ...

  8. java简单学生成绩管理系统

    题目要求: 一. 数据结构要求:(5 分) 1.定义 ScoreInformation 类,其中包括七个私有变量(stunumber, name, mathematicsscore, englishi ...

  9. java学生成绩管理系统

                                                       信1805-1 20183590 田庆辉             石家庄铁道大学 2019 年秋季 ...

随机推荐

  1. tree 向上查找(更新删除后页面的数据)

    需求 : 根据选择的id,需要找到一整条tree,id以及id数据的子集都已被删除(向下查找-----上一篇笔记),此时需要更新页面的数据(向上查找) //知道最底层的节点的id,查找满足id的整个t ...

  2. RBTree和AVL

      红黑树和AVL的相同:都是平衡二叉树,所以插入删除修改查询都非常高效. 红黑树和AVL的区别: 红黑树:  不是要求绝对平衡,付出的代价是要着色,查询次数可能会多一层,好处是减少旋转次数. AVL ...

  3. 「C语言」在Windows平台搭建C语言开发环境的多种方式

    新接触C语言,如何在Windows下进行C语言开发环境的搭建值得思考并整理. 以下多种开发方式择一即可(DEV C++无须环境准备). 注:本文知识来源于  Windows 平台搭建C语言集成开发环境 ...

  4. UVa 1395 - Slim Span(最小生成树变形)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  5. BZOJ2440:[中山市选2011]完全平方数(莫比乌斯函数)

    Description 小 X 自幼就很喜欢数.但奇怪的是,他十分讨厌完全平方数.他觉得这些数看起来很令人难受.由此,他也讨厌所有是完全平方数的正整数倍的数.然而这丝毫不影响他对其他数的热爱. 这天是 ...

  6. JS解析json数据(如何将json字符串转化为数组)

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD ...

  7. 课时53.video标签(掌握)

    这节课来学习一下html5中新增的标签,我们先来看一下,html5中新增了哪些标签? 打开W3school的网页,点击参考手册中的HTML/HTML5标签,有一个按字母顺序排列的标签,但凡标签后面带有 ...

  8. 【oracle笔记1】基础知识大集锦:增删改,数据类型,用户操作,持续更新中···

    什么是数据库?数据库就是用来存储和管理数据的仓库.首先我来简单介绍一下各数据库的背景,常见的数据库如下,oracle:甲骨文公司(市场占用率最高),oracle也是一个公司名,翻译过来就是甲骨文的意思 ...

  9. 最优贸易(tarjan,spfa)

    题目描述 C国有n个大城市和m 条道路,每条道路连接这 n个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双向通行的道 ...

  10. mysql 的基本操作总结--增删改查

    本文只是总结一下mysql 的基本操作,增删改查,以便忘记的时候可以查询一下 1.创建数据库 语法:CREATE DATABASES 数据库名; 例子: CREATE DATABASES studen ...