JAVA课程设计个人博客 学生成绩管理 201521123001 张陈东芳
1. 团队课程设计博客链接 http://www.cnblogs.com/kawajiang/p/7062407.html
2.个人负责模块或任务说明
我主要负责实现学生信息的添加功能、学生成绩的录入功能、对单个学生各科成绩画出柱状分布图功能和小组博客内容收集整理。
3.自己的代码提交记录截图


4.自己负责模块或任务详细说明
学生信息的添加功能
代码
public boolean writeStudent(Student student) { //添加学生
Connection conn = null;//创建数据库连接对象
PreparedStatement pstat = null;//使用PreparedStatement进行参数化查询
String sql = ("insert into insert into student(id,name,gender,birthday )"+ "values(?,?,?,?)");//插入数据
int result = -1;
try {
conn = JDBCUtil.getConnection();
pstat = conn.prepareStatement(sql);
pstat.setInt(1, student.getId());
pstat.setString(2, student.getName());
pstat.setString(3, student.getGender());
pstat.setDate(4, new java.sql.Date(student.getBirthday().getTime()));
result = pstat.executeUpdate();//设置参数
} catch (SQLException sqle) {
sqle.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCUtil.realeaseAll(null, pstat, conn);
}
return result > 0 ? true : false;
}
截图

学生成绩的录入功能
代码
public boolean update(Student student) { //修改学生信息or输入学生的成绩
// 拿到连接对象
Connection conn = null;// 创建预处理命令对象
PreparedStatement pstmt = null;
int n = 0;
try {
conn = JDBCUtil.getConnection();
pstmt = conn.prepareStatement("update student set name=?,gender=?,birthday=?,数学=?,Java=?,体育=?");
pstmt.setString(1, student.getName());
pstmt.setString(2, student.getGender());
pstmt.setDate(3, new java.sql.Date(student.getBirthday().getTime()));
pstmt.setDouble(4, student.getScoreList().get(0).getScore());
pstmt.setDouble(5, student.getScoreList().get(1).getScore());
pstmt.setDouble(6, student.getScoreList().get(2).getScore());
n = pstmt.executeUpdate();
System.out.println("插入语句执行结果-----" + n);
} catch (SQLException e) {
e.printStackTrace();
} finally {
JDBCUtil.realeaseAll(null, pstmt, conn);
}
return n > 0 ? true : false;
}
对单个学生各科成绩画出柱状分布图功能
代码
public class main extends JPanel {
private double[] value;
private String[] classes;
private String title;
public main(double[] val, String[] lang, String t) {
classes = lang;
value = val;
title = t;
}
public void paintComponent(Graphics graphics) {
super.paintComponent(graphics);//绘制窗体
double minValue = 0;//柱形最小值
double maxValue = 0;//柱形最大值
for (int i = 0; i < value.length; i++) {
if (minValue > value[i])
minValue = value[i];
if (maxValue < value[i])
maxValue = value[i];
}//将数据的最大最小值记为柱形的大小范围
Dimension dim = getSize();//设置图形的长宽
int clientWidth = dim.width;//定义窗体宽度
int clientHeight = dim.height;//定义窗体高度
int barWidth = clientWidth / value.length;//每条柱形平均宽度
Font titleFont = new Font("gb2312", Font.BOLD, 20);
//标题格式为gb2312才不会导致中文乱码
//中文 加粗 20号字体
FontMetrics titleFontMetrics = graphics.getFontMetrics(titleFont);
Font labelFont = new Font("gb2312", Font.PLAIN, 15);
//数据名称格式为gb2312才不会导致中文乱码
FontMetrics labelFontMetrics = graphics.getFontMetrics(labelFont);
int titleWidth = titleFontMetrics.stringWidth(title);//标题总宽度
int q = titleFontMetrics.getAscent() + 3;//标题距上界距离
int p = (clientWidth - titleWidth) / 2;//设置为居中
graphics.setFont(titleFont);//标题输出格式设置完成
graphics.drawString(title, p, q);
//输出标题
//str - 要绘制的 string。
//x - x 坐标。
//y - y 坐标。
int top = titleFontMetrics.getHeight();//图形区域上边缘坐标等于标题高度
int bottom = labelFontMetrics.getHeight();//图形区域下边缘坐标等于数据名称高度
double scale = (clientHeight - top - bottom) / (maxValue - minValue);//单位高度
q = clientHeight - labelFontMetrics.getDescent();
//设置数据名称y坐标,为窗体高度-文本基线到下降线距离
graphics.setFont(labelFont);//数据名称输出格式设置完成
for (int j = 0; j < value.length; j++) {
int valueP = j * barWidth + 1;//要填充矩形的 x 坐标
int valueQ = top;//要填充矩形的 y 坐标
int height = (int) (value[j] * scale);//要填充矩形的高度
valueQ += (int) ((maxValue - value[j]) * scale);//要填充矩形的宽度
graphics.setColor(Color.lightGray);//设置柱形图颜色
graphics.fillRect(valueP, valueQ, barWidth, height);
//填充柱形图
graphics.setColor(Color.darkGray);//设置边框颜色
graphics.drawRect(valueP, valueQ, barWidth, height);
//柱形图边框
int labelWidth = labelFontMetrics.stringWidth(classes[j]);
p = j * barWidth + (barWidth - labelWidth) / 2;
graphics.setColor(Color.black);//设置数据名称颜色
graphics.drawString(classes[j], p, q);
//设置柱状图的坐标
//str - 要呈现的字符串
//x - 呈现 String 位置的 x 坐标
//y - 呈现 String 位置的 y 坐标
}
}
public static void main(Student s) {
JFrame frame = new JFrame();
frame.setSize(400, 300);//设置窗口大小
double[] value= new double[3];
String[] classes = new String[3];
value[0] = s.getScoreList().get(0).getScore();
classes[0] = "数学";
value[1] = s.getScoreList().get(1).getScore();
classes[1] = "Java";
value[2] = s.getScoreList().get(2).getScore();
classes[2] = "体育";
frame.getContentPane().add(new main(value, classes,s.setName(name) + "的成绩单"));
//输出柱形图各数据名称
WindowListener winListener = new WindowAdapter() {
public void windowClosing(WindowEvent event) {
System.exit(0);
}
};
frame.addWindowListener(winListener);//建立一个窗口
frame.setVisible(true);//弹出窗口
}
}
截图

5.课程设计感想
学习要在实践中摸索才有实际成效,在编写函数的同时也提升了查找关键字的能力。这次课设可以实现学生信息的增删改查、对单个学生各科成绩画出柱状分布图功能和将学生信息汇总成excel功能,但还未实现多名学生同时生成成绩对比图,柱状图的画面质感也有待改进。我们希望在暑假能进一步完善功能,做出真正能够投入使用的学生成绩管理系统。
JAVA课程设计个人博客 学生成绩管理 201521123001 张陈东芳的更多相关文章
- JAVA课程设计个人博客 学生成绩管理 201521123023 戴建钊
1. 团队课程设计博客链接 http://www.cnblogs.com/kawajiang/p/7062407.html 2.个人负责模块或任务说明 我主要负责实现随机生成10万个学生及其姓名.学号 ...
- JAVA课程设计个人博客 学生成绩管理 201521123014 黄绍桦
1. 团队课程设计博客链接 http://www.cnblogs.com/kawajiang/p/7062407.html 2.个人负责模块或任务说明 本人主要负责DAO模式.添加和修改学生的信息功能 ...
- JAVA课程设计个人博客 学生成绩管理 201521145048 林健
1. 团队课程设计博客链接 http://www.cnblogs.com/kawajiang/p/7062407.html 2.个人负责模块或任务说明 本人主要负责支持用户登录.验证操作,显示设计界面 ...
- JAVA课程设计个人博客 学生基本信息管理 201521123117 李心宇
1. 团队课程设计博客链接 http://www.cnblogs.com/ll321/p/7067598.html 2.个人负责模块或任务说明 ①主要有三个界面的设计,包括:登录界面,功能选择界面还有 ...
- JAVA课程设计——团队博客
JAVA课程设计--团队博客 1. 团队名称.团队成员介绍(需要有照片) 团队名称:"小羊吃蓝莓"小游戏 团队成员介绍: 成员 班级 学号 廖怡洁 网络1513 201521123 ...
- java课程设计团队博客
java课程设计 本组主题:Calculator(简易计算器) 功能要求:基本实现计算器的功能,可运行加.减.乘.除.求倒数.求平方根.求百分号运算.正负数运算等 一.团队介绍 团队名称:熬夜做不出随 ...
- java课程设计团队博客《基于学院的搜索引擎》
JAVA课程设计 基于学院网站的搜索引擎 对学院网站用爬虫进行抓取.建索(需要中文分词).排序(可选).搜索.数据摘要高亮.分页显示.Web界面. 一.团队介绍 学号 班级 姓名 简介 2016211 ...
- Java课程设计---团队博客
课设题目:购物车系统 题目要求: 1.先建立一个文本文件,定义出自己想要的商品.//也可用数据库以商品编号:商品名称:商品品牌:价格作为文件的内容,中间要求用分号或者分割 2.编写程序,定义一个商品类 ...
- Python课程设计 搭建博客
安装包Github地址 Python综合设计 233博客 注意还有个email文件是需要填入自己信息的,比如最高权限账号和要发送邮件的账号密码 请安装Python2.7环境,本服务器所用环境为 设置环 ...
随机推荐
- Oracle外键需要建索引吗?
关于Oracle中的外键,首先要说明一下. 1. 除非已定义了父表主键或唯一键约束,否则oracle将不允许创建子表的外键约束. 2. 在定义外键约束时,oracle不会自动创建索引,所以必须手动在与 ...
- BZOJ 3028 食物 生成函数
Description 明明这次又要出去旅游了,和上次不同的是,他这次要去宇宙探险!我们暂且不讨论他有多么NC,他又幻想了他应 该带一些什么东西.理所当然的,你当然要帮他计算携带N件物品的方案数.他这 ...
- 做的简单的一个静态web服务器,遇到个bug, 提示osError,这点一不小心就错了,特地记下来,加深记忆,socket须先绑定,再listen,如果是先listen再绑定,系统会自动分配一个端口,而程序绑定不了
代码改正之前,先执行了listen,到了bind就报错:此程序只需将listen和改到bind后面即可 from socket import *from multiprocessing import ...
- WebApp开发总结
WebApp开发总结 框架的使用网络上都有教程,就不写了,主要记录下个人的开发总结以方便以后开发注意. css公用样式统一定义 css样式抽出复用 appearance: none; 取消系统默认样式 ...
- [Linux] Desktop Management
xrandr --output Virtual1 --mode 1360x768 Extend Display Size
- javaweb中重定向和请求转发(response.sendRedirect()和request.getRequestDispatcher(rul).forward(request,response)))的区别
先来两张图,方便理解: 可以看出,重定向时,是服务器向游览器重新发送了一个response命令,让游览器再次向url2发送请求,以获取url2的资源 而请求转发时,类似于是服务器自己向自己发了一个跳转 ...
- [js高手之路]设计模式系列课程-发布者,订阅者重构购物车
发布者订阅者模式,是一种很常见的模式,比如: 一.买卖房子 生活中的买房,卖房,中介就构成了一个发布订阅者模式,买房的人,一般需要的是房源,价格,使用面积等信息,他充当了订阅者的角色 中介拿到卖主的房 ...
- DRAM(MT48LC8M32B2)学习
Micron公司,型号为MT48LC8M32B2的DRAM,其86PIN的 TSOP封装引脚定义 Micron公司,型号为MT48LC8M32B2的DRAM,其86PIN的 TSOP封装引脚定义如上图 ...
- Spring框架——批处理(batch)和事务(Transaction)
批处理(batch) 批处理(batch)------------>好比快递员[不能一件一件的送快递] - 批处理指的是一次操作中执行多条SQL语句 - 批处理相比于一次一次执行效率会提高很多 ...
- hdu4746 Mophues
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4746 题意:给出n, m, p,求有多少对a, b满足gcd(a, b)的素因子个数<=p,(其 ...