java课程设计学生成绩管理系统.doc

上传人:叶*** 文档编号:35115901 上传时间:2022-08-20 格式:DOC 页数:71 大小:175KB
返回 下载 相关 举报
java课程设计学生成绩管理系统.doc_第1页
第1页 / 共71页
java课程设计学生成绩管理系统.doc_第2页
第2页 / 共71页
点击查看更多>>
资源描述

《java课程设计学生成绩管理系统.doc》由会员分享,可在线阅读,更多相关《java课程设计学生成绩管理系统.doc(71页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、课程设计(论文)任务书 软 件 学 院 学院 软件工程 专业 103 班 一、课程设计(论文)题目 学籍管理系统 二、课程设计(论文)工作自 2011 年 12 月 12 日起至 2011 年 12 月 16 日止。三、课程设计(论文) 地点: 软 件 学 院 实 训 中 心 四、课程设计(论文)内容要求:1本课程设计的目的(1)掌握Java语言的程序设计方法; (2)理论联系实际,进一步提高学生的软件开发技术;(3)培养学生分析、解决问题的能力;(4)提高学生实践论文撰写能力。2课程设计的任务及要求1)课程设计任务:设计基于文件结构的学籍管理系统,实现以下功能:(1)录入学生基本信息的功能(

2、2)修改学生基本信息的功能(3)查询学生基本信息的功能(4)删除学生基本信息的功能2)创新要求:实现数据库的链接,并能实现数据的录入及输出。3)课程设计论文编写要求(1)课程设计任务及要求(2)设计思路-工作原理、功能规划(3)详细设计-数据分析、算法思路、类设计、功能实现(含程序流程图、主要代码及注释)、界面等。(4)运行调试及分析讨论-给出运行屏幕截图,分析运行结果,有何改进想法等。(5)设计体会及小结-设计遇到的问题及解决办法,通过设计学到了哪些新知识,巩固了哪些知识,有哪些提高。(6)参考文献(必须按标准格式列出,可参考教材后面的参考文献格式)(7)报告按规定排版打印,要求装订平整,否

3、则要求返工;(8)课设报告的装订顺序如下:封面-任务书-中文摘要-目录-正文-附录(代码及相关图片)(9)严禁抄袭,如有发现,按不及格处理。4)课程设计评分标准: (1)学习态度:20分;(2)程序检查:20分;(3)课设答辩:20分;(4)课设报告:40分。5)参考文献:(1)丁振凡. Java语言实用教程(第2版)M. 清华大学出版社. 2008.1 (2) ( 3 ) 6)课程设计进度安排1准备阶段(4学时):选择设计题目、了解设计目的要求、查阅相关资料2程序模块设计分析阶段(4学时):程序总体设计、详细设计3代码编写调试阶段(8学时):程序模块代码编写、调试、测试4撰写论文阶段(4学时

4、):总结课程设计任务和设计内容,撰写课程设计论文学生签名: 2011 年 12 月 12 日课程设计(论文)评审意见(1)学习态度(20分):优()、良()、中()、一般()、差(); (2)程序检查(20分):优()、良()、中()、一般()、差();(3)课设答辩(20分):优()、良()、中()、一般()、差();(5)论文撰写(40分):优()、良()、中()、一般()、差(); 评阅人: 职称: 讲师 2011 年 12 月 16 日中文摘要本文论述某学校学生学籍管理系统的开发过程。全文分课程任务及要求、需求分析、设计思路、详细设计、运行调试及分析讨论设计体及小结及参考文献共七部份内

5、容。本系统以Java Eclipse为开发平台,选择了易学易用可java图形界面开发编程语言,主要用到了swing、awt、sql三个类包,结合单位实际,利用软件工程化思想和方法,总体上用结构化生命周期法进行系统分析和设计,采用快速原型法来实现系统。在程序设计及调试上采用了自上而下、逐步细化,逐步完善的原则。采用结构化的功能模块设计系统功能,可读性好,易于扩充。系统由学生基本信息添加、学生基本信息查询、学生基本信息删除、学生基本信息修改及学籍管理系统退出系统等功能模块组成,基本功能较全面。本系统用户界面友好、清晰、操作简便,易学易用;系统可读性好,易于维护、更新,安全性较好。本系统采用传统下拉

6、菜单功能选择,方便、快捷、一目了然,并且在一个窗体中进行操作,每个功能界面颜色不同,这样可使系统可视化性比较强。对学生的基本信息进行简单操作,可按学号进行查询、修改、删除操作。本系统采用链入数据库进行存储,可动态进行查看、操作,这样的系统可修改性较强。目录一、课程设计任务及要求1二、需求分析2三、设计思路4四、详细设计7五、运行调试及分析讨论18六、设计体会及小结22七、参考文献23八、附录24一、课程设计任务及要求课程设计任务:学籍管理系统课程设计要求: 录入学生基本信息 修改学生基本信息 查询学生基本信息 删除学生基本信息 通过这次的设计,主要是做出一个小型的学生学籍管理系统,来加强对JA

7、VA所学知识的巩固和融会贯通,主要是在图形界面方面可以说是对一个学期所学知识的一个小结,加深对JAVA数据库的理解。二、需求分析 该学生学籍管理系统的所有功能均在一个Frame窗体中实现。学生学籍管理系统主界面模块: 采用Frame窗体来设置欢迎界面包括背景图片及字幕(可以设计成滚动字幕效果),左上方的菜单条设计成下拉式。包括“录入学生基本信息”、“修改学生基本信息”、“删除学生基本信息”、“查询学生基本信息”和“退出系统”五项菜单项。录入学生基本信息模块: 采用Panel面板来设置该部分内容信息并采用方位布局(边缘布局)和Box轻量级组件来设置“学号”、“姓名”、“性别”、“专业”、“年级”

8、、“出生”,并在该面板中添加了“录入”和“重置”两个按钮进行监听,最后将该面板加入到Frame窗体中去。修改学生基本信息模板: 采用Panel面板来设置该部分内容信息,同样是采用方位布局及Box组件来设置相关信息,并在学号旁设置了“开始修改”按钮。在面板南部方位添加了“确定修改”和“重置”两按钮进行监听。查询学生基本信息模板: 采用Panel面板来设置该部分内容信息,并将该面板加入到主窗体中去,采用边缘布局进行方位设置,在上方加入“查询”按钮进行监听。删除学生基本信息模板: 也是采用Panel面板进行设置相关内容,并用边缘布局进行布局,并在上方添加“确定”按钮,在下方添加“确定删除”按钮实现监

9、听。退出系统模板:采用JDialog组件来实现该部分功能,是以弹跳出对话框形式进行选择是否退出该系统,并设置“是”和“否”两个按钮来实现该功能的监听。综上,本学籍管理系统就是由以上六部分组成,并将所有内容信息在同一窗体中实现,这样可使系统可视化性提高。三、设计思路定义四个Panel面板用来实现该学籍管理系统对学生基本信息的操作:I.定义add(录入学生基本信息)面板来实现录入功能采用BorderLayout(构造一个组件之间没有间距的新边界布)和Box轻量级组件进行布局,在面板的Nother方位添加一个“录入学生基本信息”的标签,并更改字体,颜色等。接着用JTextField轻量级组件来设置单

10、行文本编辑,并将其加入到用createHorizontalBox()方法创建具有一个从左到右显示其组件的Box和用createHorizontalStrut()创建一个不可见的、固定宽度的组件,使其在一个横向 box 中,通常使用此方法强行使两个组件之间具有某一空间量。然后Box及Box之间用createVerticalBox()创建一个从上到下显示其组件的 Box,并用createVerticalStrut()方法创建一个不可见的、固定高度的组件,使其在一个纵向 box 中,通常使用此方法强行使两个组件之间具有某一空间量。然后在面板的South方位设置“录入”及“重置”两按钮。最后实现及数据

11、库的桥接,能够将从文本框获得的信息存储到数据库中去。II.定义Query(查询学生基本信息)面板来实现查询功能该部分同样采用BorderLayout(构造一个组件之间没有间距的新边界布)和Box轻量级组件进行布局,在面板的Nother方位添加一个“查询学生基本信息”的标签,并更改字体,颜色等。接着用JTextField轻量级组件来设置单行文本编辑,在学号这一文本框后再添加一个“查询”按钮。并将其加入到用createHorizontalBox()方法创建具有一个从左到右显示其组件的Box和用createHorizontalStrut()创建一个不可见的、固定宽度的组件,使其在一个横向 box 中

12、,通常使用此方法强行使两个组件之间具有某一空间量。然后Box及Box之间用createVerticalBox()创建一个从上到下显示其组件的 Box,并用createVerticalStrut()方法创建一个不可见的、固定高度的组件,使其在一个纵向 box 中,通常使用此方法强行使两个组件之间具有某一空间量。最后实现及数据库的桥接,能够将从数据库中获取信息并显示到文本框中去。III.定义Update(修改学生基本信息)面板来实现修改功能该部分同样也是采用BorderLayout(构造一个组件之间没有间距的新边界布)和Box轻量级组件进行布局,在面板的Nother方位添加一个“修改学生基本信息”

13、的标签,并更改字体,颜色等。接着用JTextField轻量级组件来设置单行文本编辑,并将其加入到用createHorizontalBox()方法创建具有一个从左到右显示其组件的Box和用createHorizontalStrut()创建一个不可见的、固定宽度的组件,使其在一个横向 box 中,通常使用此方法强行使两个组件之间具有某一空间量。并在 “学号”该文本框后添加一个“开始修改”按钮用来监听。然后Box及Box之间用createVerticalBox()创建一个从上到下显示其组件的 Box,并用createVerticalStrut()方法创建一个不可见的、固定高度的组件,使其在一个纵向

14、box 中,通常使用此方法强行使两个组件之间具有某一空间量。最后实现及数据库的桥接,能够将从数据库中获取信息并显示到文本框中去,并将修改后的信息存储到数据库中去。IV.定义Delete(删除学生基本信息)面板来实现删除功能该部分还是采用BorderLayout(构造一个组件之间没有间距的新边界布)和Box轻量级组件进行布局,在面板的Nother方位添加一个“修改学生基本信息”的标签,并更改字体,颜色等。接着用JTextField轻量级组件来设置单行文本编辑,在学号这一文本框后再添加一“确定”按钮实现监听。并将其所有文本框和标签加入到用createHorizontalBox()方法创建具有一个从

15、左到右显示其组件的Box和用createHorizontalStrut()创建一个不可见的、固定宽度的组件,使其在一个横向 box 中,通常使用此方法强行使两个组件之间具有某一空间量。并在 “学号”该文本框后添加一个“开始修改”按钮用来监听。然后Box及Box之间用createVerticalBox()创建一个从上到下显示其组件的 Box,并用createVerticalStrut()方法创建一个不可见的、固定高度的组件,使其在一个纵向 box 中,通常使用此方法强行使两个组件之间具有某一空间量,还在本面板的South方位添加“确定删除”按钮。最后实现及数据库的桥接,能够将从数据库中获取信息并

16、显示到文本框中去,删除后同时在数据库中也删除该信息并保存该操作。V.定义exit(退出系统)对话框来实现退出功能本部分采用JDialog来实现,在该对话框的North方位添加“确定要退出学籍管理系统吗?”这一标签,在South方位添加“是”和“否”两个按钮来实现是否退出学籍管理系统。VI定义fra(欢迎界面窗)窗体来实现下拉菜单条并进入以上五部分功能用MenuBar 类封装绑定到框架的菜单栏及Menu 对象是从菜单栏部署的下拉式菜单组件来实现下拉式菜单条。流程图如下修改学生信息录入学生信息退出管理系统删除学生信息修改学生信息学生学籍管理系统四、详细设计首先导入该程序中所需要用到的java包如下

17、:import java.sql.*;import java.awt.*;import javax.swing.*;import java.awt.event.*;import javax.swing.JOptionPane;设计录入学生基本信息这一模块功能/add(录入学生基本信息)面板(Panel)设计:class add extends Panel implements ActionListener Connection con;Statement sql;Panel pNorth, pCenter;JButton done, readd;Box box, box0, box1, box

18、2, box3, box4, box5, box6, box7;JTextField num, name, sex, birth, cla, professional;public add() setLayout(new BorderLayout();Font font = new Font(华文中宋, Font.BOLD, 22);UIManager.put(Label.font, font);num = new JTextField(20);name = new JTextField(20);sex = new JTextField(20);professional = new JText

19、Field(20);cla = new JTextField(20);birth = new JTextField(20);box0 = Box.createHorizontalBox();JLabel jl = new JLabel( 录入学生基本信息 );jl.setForeground(Color.red);jl.setFont(new Font(华文行楷, Font.BOLD, 34);box0.add(jl);box1 = Box.createHorizontalBox();box1.add(new JLabel(学号:);box1.add(Box.createHorizontalS

20、trut(8);box1.add(num);box2 = Box.createHorizontalBox();box2.add(new JLabel(姓名:);box2.add(Box.createHorizontalStrut(8);box2.add(name);box3 = Box.createHorizontalBox();box3.add(new JLabel(性别:);box3.add(Box.createHorizontalStrut(8);box3.add(sex);box4 = Box.createHorizontalBox();box4.add(new JLabel(专业:)

21、;box4.add(Box.createHorizontalStrut(8);box4.add(professional);box5 = Box.createHorizontalBox();box5.add(new JLabel(年级:);box5.add(Box.createHorizontalStrut(8);box5.add(cla);box6 = Box.createHorizontalBox();box6.add(new JLabel(出生:);box6.add(Box.createHorizontalStrut(8);box6.add(birth);box7 = Box.creat

22、eHorizontalBox();done = new JButton(录入);done.setFont(new Font(华文行楷, Font.BOLD, 22);done.setForeground(Color.black);done.setBackground(Color.white);done.addActionListener(this);box7.add(done);box7.add(Box.createHorizontalStrut(8);readd = new JButton(重置);readd.setFont(new Font(华文行楷, Font.BOLD, 22);rea

23、dd.setForeground(Color.black);readd.setBackground(Color.white);readd.addActionListener(this);box7.add(readd);box = Box.createVerticalBox();box.add(box0);box.add(Box.createVerticalStrut(12);box.add(box1);box.add(Box.createVerticalStrut(12);box.add(box2);box.add(Box.createVerticalStrut(12);box.add(box

24、3);box.add(Box.createVerticalStrut(12);box.add(box4);box.add(Box.createVerticalStrut(12);box.add(box5);box.add(Box.createVerticalStrut(12);box.add(box6);box.add(Box.createVerticalStrut(12);box.add(box7);pCenter = new Panel();pCenter.add(box);add(pCenter, Center);setBackground(Color.cyan);/实现动作事件并链接数

25、据库将文本框内信息存储到数据库中:public void actionPerformed(ActionEvent e) String num0, num1, name1, sex1, cla1, professional1, birth1;int out = 1;if (e.getSource() = done) name1 = name.getText();if (name1.equals() JOptionPane.showMessageDialog(this, 对不起,姓名不能为空!);else try Class.forName(sun.jdbc.odbc.JdbcOdbcDriver

26、); catch (java.lang.ClassNotFoundException ee) try con = DriverManager.getConnection(jdbc:odbc:stud, , );sql = con.createStatement();ResultSet rs = null;boolean Abook;rs = sql.executeQuery(select * from stud);while (rs.next() num1 = rs.getString(学号);if (num1.equals(num.getText().trim() num.setText()

27、;JOptionPane.showMessageDialog(this, 对不起,该学号已存在!, 学籍管理系统,JOptionPane.ERROR_MESSAGE);out = 0;break;con.close();sql.close(); catch (SQLException r) Class.forName(sun.jdbc.odbc.JdbcOdbcDriver); catch (java.lang.ClassNotFoundException ee) try con = DriverManager.getConnection(jdbc:odbc:stud, , );sql = c

28、on.createStatement();num1 = + num.getText().trim() + ;name1 = name.getText().trim();sex1 = + sex.getText().trim() + ;professional1 = + professional.getText().trim() + ;cla1 = + cla.getText().trim() + ;birth1 = + birth.getText().trim() + ;String temp = insert into stud values ( + num1 + ,+ + name1 +

29、+ , + sex1 + ,+ professional1 + , + cla1 + , + birth1 + );sql.executeUpdate(temp);sql.close();con.close(); catch (SQLException err) JOptionPane.showMessageDialog(this, 信息录入错误,请重新录入!, 学籍管理系统,JOptionPane.ERROR_MESSAGE);out = 0;if (out = 1) JOptionPane.showMessageDialog(this, 录入成功!, 学籍管理系统,JOptionPane.

30、INFORMATION_MESSAGE);num.setText( );name.setText( );sex.setText();cla.setText( );professional.setText( );birth.setText( );if (e.getSource() = readd) num.setText( );name.setText( );sex.setText();cla.setText( );professional.setText( );birth.setText( );设计查询(Query)这一模块、修改(Update)这一模块、删除(Delete)这一模块均和录入(

31、add)模块类似、再此不做过多介绍,详细过程见源程序代码(八、附录);设计退出(exit)对话框(Dialog)模块class exit extends JDialog implements ActionListener JFrame mainFrame;JPanel panelS, panelN;JButton yes, no;JLabel lab;public exit(JFrame mainFrame) super(mainFrame, 华东交通大学软件学院学籍管理系统, true);this.mainFrame = mainFrame;panelN = new JPanel();pan

32、elS = new JPanel();lab = new JLabel(确认要退出学籍管理系统吗?);lab.setForeground(Color.RED);lab.setFont(new Font(华文行楷, Font.PLAIN, 22);panelN.add(lab);yes = new JButton(退出);yes.setForeground(Color.RED);yes.setFont(new Font(华文行楷, Font.PLAIN, 20);yes.addActionListener(this);no = new JButton(取消);no.setFont(new Fon

33、t(华文行楷, Font.PLAIN, 20);no.setForeground(Color.RED);no.addActionListener(this);/注册监听事件panelS.add(yes);panelS.add(no);getContentPane().add(panelS, BorderLayout.SOUTH);getContentPane().add(panelN, BorderLayout.NORTH);this.setBackground(Color.yellow);this.setResizable(false); / 设置对话框为不可改变大小/以下部分为实现事件处理

34、public void actionPerformed(ActionEvent e) if (e.getSource() = yes) System.exit(0);if (e.getSource() = no) this.setVisible(false);设计fram(欢迎界面)窗体(Frame)模块/定义主窗体并加入下拉菜单条class fram extends Frame implements ActionListener MenuBar menubar;Menu menu_select;MenuItem item_stud_add, item_stud_search, item_st

35、ud_update,item_stud_delete, item_exit;add luru;Query chaxun;Update xiugai;Delete shanchu;Box box, box1, box2;fram() super(华东交通大学软件学院学生学籍管理系统);luru = new add();chaxun = new Query();xiugai = new Update();shanchu = new Delete();menubar = new MenuBar();menu_select = new Menu(菜单选项);menu_select.setFont(ne

36、w Font(华文行楷, Font.BOLD, 18);item_stud_add = new MenuItem(录入学生基本信息);item_stud_add.addActionListener(this);item_stud_update = new MenuItem(修改学生基本信息);item_stud_update.addActionListener(this);item_stud_search = new MenuItem(查询学生基本信息);item_stud_search.addActionListener(this);item_stud_delete = new MenuIt

37、em(删除学生基本信息);item_stud_delete.addActionListener(this);item_exit = new MenuItem(退出);item_exit.addActionListener(this);menu_select.add(item_stud_search);menu_select.add(item_stud_add);menu_select.add(item_stud_update);menu_select.add(item_stud_delete);menu_select.add(item_exit);menubar.add(menu_select

38、);setMenuBar(menubar);/this.setBackground(Color.green);/*ImageIcon img = new ImageIcon(E:44.png);JLabel hy = new JLabel(img);hy.setBounds(0, 0, img.getIconWidth(), img.getIconHeight();add(hy);setVisible(true);*/Label label = new Label(欢迎进入学生学籍管理系统, Label.CENTER);label.setFont(new Font(华文行楷, Font.BOL

39、D, 40);label.setForeground(Color.RED);this.add(label);/实现动作事件处理public void actionPerformed(ActionEvent e) if (e.getSource() = item_stud_add) removeAll();add(luru, Center);validate();if (e.getSource() = item_stud_search) removeAll();add(chaxun, Center);validate();if (e.getSource() = item_stud_update)

40、 removeAll();add(xiugai, Center);validate();if (e.getSource() = item_stud_delete) removeAll();add(shanchu, Center);validate();if (e.getSource() = item_exit) JFrame f4 = new JFrame();exit exit1 = new exit(f4);exit1.setBounds(500, 240, 300, 120);exit1.setVisible(true);定义整个程序的主类并在主类中创建数据库stud表格public c

41、lass stud public static void main(String args) String url = jdbc:odbc:stud;String sql = create table stud + (学号 String(20), 姓名 String(20), 性别 String(6), 专业 String(30),年级 String(20),出生 String(20);try Class.forName(sun.jdbc.odbc.JdbcOdbcDriver); catch (java.lang.ClassNotFoundException e) try Connectio

42、n con = DriverManager.getConnection(url, , null);Statement stmt = con.createStatement();stmt.executeUpdate(sql);System.out.println(student table created );stmt.close();con.close(); catch (SQLException exe) Frame fra = new fram();fra.setBounds(300, 80, 500, 400);fra.setVisible(true);/* 窗口事件处理 */fra.addWindowListener(new WindowAdapter() public void windowClosing(WindowEvent e) System.exit(0);五、运行调试及分析讨论I.运行调试部分欢迎界面登陆录入学生基本信息查询学生基本信息删除学生基本信息修改学生基本信息退出系统II.分析讨论部分(1)起初在面板的布局方面存在一些问题,如:几个按钮的方位及预期的不一致后经调试发现是没有将该面板设置为边缘布局setLayout(new BorderLayout();(2)其

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 高中资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com