一、团队名称:

团队成员

  • 林艺薇 201721123032 网络1712
  • 黄毓颖 201721123033 网络1712
  • 唐川 201721123034 网络1712
  • 梁才玉 201721123038 网络1712

任务分配

二、项目git地址

https://gitee.com/ev32/keshe/tree/master

三、项目git提交记录截图





四、项目功能架构图与主要功能流程图

思维导图

成绩管理流程图

五、项目运行截图

主界面

选择用户

教师登陆界面

教师增加学生信息



教师查看学生信息表

删除学生信息

修改学生信息





查找学生成绩

按班级查找

按姓名查找

按学号查找

各科成绩柱状图





将成绩导出到表格

学生登陆界面

学生功能





学生成绩查询功能



学生选课界面



六、项目关键代码

1.数据库代码导入表格

public  void LearningReport() throws SQLException {
ArrayList<String>list1=new ArrayList<String>(); Connection con = null; //建立数据库连接
PreparedStatement ps = null;
ResultSet rs = null;
String sql ="select * from students "; //数据库查询表格所有记录
con = JDBCUtil.getConnection();
ps = con.prepareStatement(sql);
rs = ps.executeQuery();
while(rs.next()){
list1.add(0,rs.getString("stunum"));
list1.add(1,rs.getString("name"));
list1.add(2,rs.getString("classes"));
list1.add(3,rs.getString("gender"));
list1.add(4,rs.getString("javaScore"));
list1.add(5,rs.getString("mathScore"));
list1.add(6,rs.getString("englishScore"));
System.out.println();
}
HSSFWorkbook wb=new HSSFWorkbook();//创建Workbook对象(excel的文档对象)
HSSFSheet sheet=wb.createSheet("表");//创建工作表
HSSFRow row1=sheet.createRow(0); //设置单元格内容
HSSFCell cell=row1.createCell(0);
cell.setCellValue("学生成绩表"); //合并单元格CellRangeAddress构造参数依次表示起始行,截至行,起始列, 截至列
sheet.addMergedRegion(new CellRangeAddress(0,0,0,6)); //在sheet里创建第二行,创建单元格并添加表头内容
HSSFRow row2=sheet.createRow(1);
row2.createCell(0).setCellValue("学号");
row2.createCell(1).setCellValue("名字");
row2.createCell(2).setCellValue("班级");
row2.createCell(3).setCellValue("性别");
row2.createCell(4).setCellValue("JAVA成绩");
row2.createCell(5).setCellValue("数学成绩");
row2.createCell(6).setCellValue("英语成绩"); //在sheet里从第三行开始创建表格中学生信息
int j=1;
for(int i=0;i<list1.size();i++) {
HSSFRow row=sheet.createRow(++j);
row.createCell(0).setCellValue(list1.get(i++));
row.createCell(1).setCellValue(list1.get(i++));
row.createCell(2).setCellValue(list1.get(i++));
row.createCell(3).setCellValue(list1.get(i++));
row.createCell(4).setCellValue(list1.get(i++));
row.createCell(5).setCellValue(list1.get(i++));
row.createCell(6).setCellValue(list1.get(i));
} //导入Excel表
try {
FileOutputStream fout=new FileOutputStream("D:\\students.xlsx");//文件输出流将数据写入表格
wb.write(fout);//保存Excel文件
fout.close();//关闭文件流
}catch(Exception e){
e.printStackTrace();
}finally {
JDBCUtil.realeaseAll(rs, null, con);
}
} @Override
//模糊查找
public List<Student> findStudentByStunum(String stunum) {
Connection con = null;
PreparedStatement pt = null;
ResultSet rs = null;
String sql="select * from students where stunum like '%"+stunum+"%'";
List<Student> list = new ArrayList<Student>();
try {
con = JDBCUtil.getConnection();
pt = con.prepareStatement(sql);
rs = pt.executeQuery();
while (rs.next()) {
// 封装数据
Student stu = new Student();
stu.setId(rs.getInt("id"));
stu.setName(rs.getString("name"));
stu.setStunum(rs.getString("stunum"));
stu.setClasses(rs.getInt("classes"));
stu.setGender(rs.getString("gender"));
ArrayList<Course> scoreList=new ArrayList<Course>();
Course java=new Course("java",rs.getDouble("javaScore"));
Course math=new Course("math",rs.getDouble("mathScore"));
Course english=new Course("english",rs.getDouble("englishScore"));
scoreList.add(java);
scoreList.add(math);
scoreList.add(english);
stu.setScoreList(scoreList);
list.add(stu);
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtil.realeaseAll(rs, pt, con);
} return list; }

2.柱状图的实现

public static JFreeChart createChart(CategoryDataset dataset)
{//创建一个JFreeChart
JFreeChart chart=ChartFactory.createBarChart("hi", "成绩情况",
"人数", dataset, PlotOrientation.VERTICAL, true, true, false);
//设置主标题
chart.setTitle(new TextTitle("学生成绩统计",new Font("宋体",Font.BOLD+Font.ITALIC,20)));
//获得图标中间部分,即plot
CategoryPlot plot=(CategoryPlot)chart.getPlot();
//获得横坐标
CategoryAxis categoryAxis=plot.getDomainAxis();
//设置横坐标字体
categoryAxis.setLabelFont(new Font("微软雅黑",Font.BOLD,12));
return chart;
} public static JPanel createPanel(String course) throws SQLException
{
JFreeChart chart =createChart(createDataset(course));
//将chart对象放入Panel面板中去,ChartPanel类已继承Jpanel
return new ChartPanel(chart);
}

七、项目代码扫描结果及改正。

错误一:重写类中的方法是没加方法重写标记

修改后

错误二:if语句缺少大括号

错误三:

八、尚待改进或者新的想法

  • 注册和登录功能还不太完善。
  • 没有实现多线程。
  • Gui界面不太美观。
  • jFreeChart柱状图关闭时会默认关闭所有窗口,柱状图功能还不够完善。

Java课程设计--学生成绩管理系统的更多相关文章

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

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

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

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

  3. Java课程设计—学生成绩管理系统(201521123004-林艺如)

    1.团队课程设计博客 团队课程设计博客链接 2.个人负责模块或任务说明 ①.Menu Menu.jsp 在页面中给出提示,用HTML的 MenuTeacher.jsp 利用Menu.jsp进行具体化完 ...

  4. Java课程设计—学生成绩管理系统(201521123002 林楚虹)

    1. 团队课程设计博客链接 团队博客链接 2.个人责模块或任务说明 根据学生学号查找学生成绩 根据学生姓名(支持模糊匹配)查找学生成绩 用POI技术导出Excel文件 3.自己的代码提交记录截图 4. ...

  5. Java课程设计—学生成绩管理系统

    一. 团队名称.团队成员介绍(需要有照片) 团队名称:进击的712 团队成员 杨雪莹[组长] 201521123005 网络1511 林楚虹 201521123002 网络1511 董美凤 20152 ...

  6. Java课程设计—学生成绩管理系统(54号童欢)

    1. 团队课程设计博客链接 http://www.cnblogs.com/wufuckshuo/p/7063183.html 2.个人责模块或任务说明 负责模块/任务:主函数(调用其他的功能函数),添 ...

  7. JAVA课程设计 学生成绩管理

    学生成绩管理 可实现功能: 添加学生功能:姓名.学号.性别.出生年月日.(学号自动生成且唯一) 添加学生成绩功能:每个人都有数学.Java与体育四门课,可分课程输入成绩. 根据学生学号查找学生成绩功能 ...

  8. JAVA课程设计---学生基本信息管理系统(201521123039 王兴)

    1.团队课程设计博客链接 http://www.cnblogs.com/zyjjj/p/7061880.html 2.个人负责模块或任务说明 函数 功能说明 Search 查找学生信息,分为两种查找方 ...

  9. Java课程设计 学生基本信息管理系统 团队博客

    学生基本信息管理系统团队博客 项目git地址 https://git.oschina.net/Java_goddess/kechengsheji 项目git提交记录截图 项目功能架构图与主要功能流程图 ...

随机推荐

  1. 范围for语句的整理

    1.如何处理stirng中的每个字符?(来自C++Primer中文版5th中P83) 使用基于范围的for语句,比如下面的例子,输出每个字符 #include<iostream> #inc ...

  2. ubuntu系统下的docker

    官网:https://www.docker.com/ 相关资料:1.Docker入门教程 http://dockone.io/article/1112.Docker_百度百科 http://baike ...

  3. 访问本地方站出现EOF的分析和解决

    每天早晨打开电脑运行本地项目的时候,有时候浏览器上会出现EOF 之前都都能正常访问,所以我猜想本地的项目本身肯定是没有问题的. Google了下,发现有人说是代理的问题,于是关闭代理试过后,发现可以访 ...

  4. shell 输出带颜色字体

    输出特效格式控制:\033[0m  关闭所有属性  \033[1m   设置高亮度  \03[4m   下划线  \033[5m   闪烁  \033[7m   反显  \033[8m   消隐  \ ...

  5. Django---admin简单功能

    admin admin是django强大功能之一,它能共从数据库中读取数据,呈现在页面中,进行管理.默认情况下,它的功能已经非常强大,如果你不需要复杂的功能,它已经够用,但是有时候,一些特殊的功能还需 ...

  6. HTML中的【块】与【内嵌】

    块元素与内嵌元素 块的特征 默认独占一行 没有宽度时默认撑满一行 支持所有的css命令 内嵌的特征 同行可以连续跟同类的标签 内容撑开宽度 不支持宽高 不支持上下的内外边距 代码换行被解析 块与内嵌的 ...

  7. MySQL索引介绍

    引言 今天Qi号与大家分享什么是索引.其实索引:索引就相当于书的目录 索引介绍 用官方的话说就是 索引是为了加速对表中数据行的检索而创建的一种分散的存储结构.索引是针对表而建立的,它是由数据页面以外的 ...

  8. JDBC 的使用

    使用 MariaDB,JDBC 所有操作全部使用预处理 SQL 的基本类型与 Java 类型的对应关系 CHAR(N) - String VARCHAR(N) - String BOOLEN - bo ...

  9. 使用maven插件生成grpc所需要的Java代码

    1.首先需要编写自己需要的.proto文件,本文重点不在这里,.proto可以参考grpc官方例子 https://grpc.io/docs/quickstart/java.html 2.创建自己的J ...

  10. linux redhat 打开防火墙中的某个端口

    服务器成功监听了一个端口(如 5500),但是外面连接不进来,telnet其端口不通,解决办法如下(在root用户下): $ /sbin/iptables -I INPUT -p tcp --dpor ...