JavaWeb——升级赛-学生成绩管理系统(2).java---19.01.03
dao.java
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import DBUtil.DBUtil;
{
//添加
//@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;
}
}
{
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;
}
}
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();
}
}
}
import java.util.List;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import Dao.service;
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);
}
}
//添加
{
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的更多相关文章
- JavaWeb——升级赛-学生成绩管理系统(1)jsp---19.01.03
add.jsp <%@ page language="java" contentType="text/html; charset=UTF-8" pa ...
- Java项目:学生成绩管理系统(二)
学生成绩管理系统(二):项目介绍 一.设计要求: 1.1 简单的图形界面登录功能. 1.2 对数据库的的信息的查询功能. 1.3 对数据库的的信息的修改功能. 1.4 对数据库的的信息的删除功能. 1 ...
- 学生成绩管理系统 1.0(Java+MySql)
真难…… 数据库建立不会,中文编码不会,插入数据不会,删除不会…… Java读入数据不会……数据库连接不会…… 你也好意思说自己是学计算机的啊魂淡…… 我会慢慢写2.0,3.0版的……噗…… src/ ...
- 使用Java模拟一个简单的Dos学生成绩管理系统:
使用Java模拟学生成绩管理系统... ------------------- 学生成绩管理系统:需要实现的功能:1.录入学生的姓名和成绩2.显示列表.列表中包括学生姓名与成绩3.显示最高分.最低分的 ...
- Java课程设计—学生成绩管理系统(201521123005 杨雪莹)
一.团队课程设计博客链接 学生成绩管理系统 二.个人负责模块或任务说明 学生成绩录入 显示所有学生信息 显示各科平均成绩 显示学生成绩(按降序排序) 三.自己的代码提交记录截图 四.自己负责模块或任务 ...
- Java课程设计——学生成绩管理系统(201521123003 董美凤)
Java课程设计--学生成绩管理系统(201521123003 董美凤) 1.团队课程设计博客链接 学生成绩管理系统博客链接 2.个人负责模块或任务说明 信息修改 密码修改 部分界面设计 3.自己的代 ...
- Java开学测试-学生成绩管理系统
题目: 1.定义 ScoreInformation 类,其中包括七个私有变量(stunumber, name, mathematicsscore, englishiscore,networkscore ...
- java简单学生成绩管理系统
题目要求: 一. 数据结构要求:(5 分) 1.定义 ScoreInformation 类,其中包括七个私有变量(stunumber, name, mathematicsscore, englishi ...
- java学生成绩管理系统
信1805-1 20183590 田庆辉 石家庄铁道大学 2019 年秋季 ...
随机推荐
- 设计模式:访问者(Visitor)模式
设计模式:访问者(Visitor)模式 一.前言 什么叫做访问,如果大家学过数据结构,对于这点就很清晰了,遍历就是访问的一般形式,单独读取一个元素进行相应的处理也叫作访问,读取到想要查看的内容+ ...
- linux配置sudo
编辑/etc/sudoers或者直接使用root用户运行visodu 添加如下两行:oracle ALL=(ALL) NOPASSWD: ALLoinstall ALL=( ...
- Linux:CentOS7卸载mysql
步骤 方法一. 1.查看mysql安装 rpm -qa|grep -i mysql 2.卸载前关闭mysql服务 rpm -ev --nodeps mysql-community-release-el ...
- docker中自定ingress网络
在某些时候,docker自动生成的ingress网络会与服务器上已经存在的网络产生冲突,这个时候,你需要自定义ingress. 在自定义前,你需要删除所有有端口发布的服务. 使用命令docker ne ...
- SAP S/4HANA里如何创建Customer主数据以及执行后续处理
来自Jerry的同事Zhang Sean. 1, Launch tcode: BP and select the Organization 2, Maintain the information fo ...
- gulp使用方法总结
gulp是用于前端构建的基于文件流的一套工具.可以用于压缩.编译.合并.检查文件等操作.可以节省大量的用于繁琐重复操作的人力.最开始就是安装gulp工具了,在命令行中切换到工作的文件目录下,安装gul ...
- 使用commons-fileupload-1.2.1.jar等组件实现文件上传
使用的主要jar包:commons-io-1.3.2.jar包;commons-fileupload-1.2.1.jar包:commons-lang-2.3.jar,在使用组件实现文件上传时候要注意前 ...
- Android HttpClient自己主动登陆discuz论坛!
你登陆论坛的时候,我们先看看浏览器干了什么事儿: 用Firefox打开HiPda 的登陆页面,输入用户名和password,点登陆. 以下是通过firebug插件获取的数据: 能够看到浏览器这个htt ...
- 六.安装jdk(基于Centos7安装)
1.我把java安装到/usr/local/jdk目录下面,所以,新建文件夹如下 2.把下载到的文件上传至Linux服务器 笔者使用wget命令直接把文件下载到服务器"wget http:/ ...
- MyBatis(1)优点&介绍&工程
本次全部学习内容:MyBatisLearning 一:jabc的相关说明: jdbc编程步骤: 加载数据库驱动 创建并获取数据库链接 创建jdbc statement对象 设置sql语句 设置sql语 ...