ImageVerifierCode 换一换
格式:DOCX , 页数:51 ,大小:1.70MB ,
资源ID:7264651      下载积分:2 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7264651.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(sql server学生成绩管理系统课程设计.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

sql server学生成绩管理系统课程设计.docx

1、sql server学生成绩管理系统课程设计 目录 需求分析1.1 功能需求我做的是学生成绩管理系统,设计到的主要用户有两大类,即教师和学生。从学生的角度来看,需要实现的功能有查询基本信息,查询成绩,修改密码。这三项功能是学生成绩管理系统所必须具备的,其余功能可以具体分析是否添加。我做的系统的学生界面就是基于这三个功能进行的。从教师的角度来看,需要实现的功能有录入学生基本信息,录入学生的各科成绩,修改教师登录系统的密码,以及修改学生成绩。1.2 系统的开发运行环境本系统开发平台: Java 或其他可视化高级语言+ sql servereclipse本系统运行环境: windows 7 总体设计

2、2.1 系统功能模块为了简化学生管理系统,将系统划分为三个模块,即:登录模块,教师模块,学生模块。功能模块实现用户的登录,用户主要为两类:学生,教师。其中登录账号即为学生的学号与教师的教师号,学生的初始密码为123,教师的初始密码为教师号。登录系统之后要及时进行修改。教师模块实现对学生成绩与基本信息的管理。即录入学生信息,录入学生成绩,修改成绩,修改密码学生模块实现对信息的查询与更改,查询即为查询学生的基本信息,查询学生的成绩,以及更改密码。 系统总体结构图2.2 主要类设计(子模块设计)学生成绩管理系统由9个类组成,分别是:系统类,教师类,学生类,添加信息类,添加成绩类,修改成绩类,修改密码

3、类,查询基本信息类,查询成绩类。系统类实现用户的登录,验证用户的身份。学生的登录账号为学号,初始密码为123。教师的登录账号为教师号,初始密码为教师号。当登录账号输入有错时,系统会提示登录失败。教师成功登录系统之后进入的是教师界面,教师自由的选择要实现的功能。教师可以录入学生的基本信息,录入学生的成绩,修改学生的成绩,修改教师的登录密码。教师选择录入学生的基本信息之后系统就弹出了录入信息类,通过添加学生的学号,姓名,性别,班级,学院,备注,出生年月,点击添加按钮实现向数据库添加学生信息。教师选择录入学生的成绩之后,录入成绩的界面弹出。教师根据学号,一次添加学生的各科成绩之后,点击添加实现向数据

4、库中添加学生的成绩。同时教师也可以修改学生的成绩,因为考虑到教师的误操作,所以设置了修改学生成绩类。教师只要输入学号再加上要修改的学生的科目的成绩之后点击添加即可。为了避免账号被人随意登录,教师可在首次登录系统之后进行密码的修改。学生成功登录系统之后进入的是学生界面,学生界面主要实现一些基本的查询功能,如查询学生的基本信息,查询学生的成绩,修改学生的登录密码等。学生选择查询基本信息之后系统随即弹出查询信息类的界面,学生不需要输入学号,点击查询即可。同时学生可以选择查询成绩,点击之后系统自动弹出查询成绩类的界面,学生不需要输入学号即可实现查询。因为学生成绩管理系统的初始登录密码为123,所以学生

5、登录之后的第一件事是修改登录密码。数据库设计3.1 数据表设计(要体现数据完整性)学生成绩管理系统共有四个表,分别是:学生表,成绩表,教师表,课程表。表的设计如下:学生表(学号,姓名,性别,初始年月,专业班级,总学分,备注,班级,学校,密码);教师表(教师号,姓名,性别,学校,密码);课程表(课程号,课程名,教师号,学分,学时);3.2 存储过程与触发器设计存数过程是数据库对象之一,存储过程可以理解为数据库的子程序,在客户端和服务端可以使用它。触发器是与表直接关联的特殊的存储过程,是对表记录操作时触发的。在数据库设计过程中,均对存储过程和触发器进行了设计。定义select * from xsb

6、存储过程:create procedure student_info as select * from xsb exec student_info定义select * from TCH 存储过程:create procedure tch_info as select * from tchexec tch_info定义select * from xsb存储过程:create procedure xsb_info_search asselect * from xsb where 学号 = + id + 创建触发器,当向学生表中插入一行数据时,提示“trigger is working”create

7、 trigger xsb_insert on xsb after insertas begin declare str char(50)set str=trigger is workingprint str end创建触发器,当想xsb中插入一个学生的成绩时,将xsb表中的该学生的总学分加上添 加的课程的学分create trigger cjb_insert on cjb after insertas begindeclare num char(6),kc_num char(3)declare xf int select num=kcb.学分,kc_num=kcb.课程号 from inser

8、ted select xf=学分 from kcb where kcb.课程号=kc_numupdate xsb set 总学分=总学分+xf where 学号=numprint修改成功End创建触发器,当修改xsb表中的学号时,同时也要将cjb表中的学号修改成相应的学 号create trigger xsb_updateon xsb after updateasbegin declare old_num char(6),new_num char(6)select old_num=学号 from deletedselect new_num=学号 from inserted update cjb

9、 set 学号=new_num where 学号=old_numend创建xscjgl数据库作用域的ddl触发器,当删除一个表时,提示禁止该操作,然后回 滚删除表的操作。create trigger safetyon databaseafter drop_tableas print 不能删除该表rollback transaction 创建服务器作用域的ddl触发器,当删除一个数据库时,提示禁止该操作并回滚删除数据库的操作。create trigger safety_server_deleteon all serverafter drop_databaseas print 不能删除该数据库ro

10、llback transaction3.3 索引(视图)设计Sql server中索引可以分为两类,即聚集索引和非聚集索引。索引是可以唯一的,这意味着不会有两行相同的索引键值,这样的索引称为唯一索引。聚集索引将数据行的键值在表内排序并存储对应的数据记录,使得数据表物理顺序与索引顺序一致。非聚集完全独立于数据行的结构。本系统使用的是唯一索引,这是因为考虑到每个表中都不允许出现两行一样的值,约束输入数据的正确规范,保证数据的完整性。创建唯一聚集索引:create unique clustered index xsb_id_ind on xsb(学号)create unique clustered

11、index tch_id_ind on tch(教师号)create unique clustered index cjb_id_ind on cjb(学号)3.4 安全性设计对于学生成绩管理系统的安全性设计,我是从两个方面去考虑的。其一是数据库的备份与恢复。其二是系统安全管理。创建备份:在本地硬盘上创建一个备份文件,备份设备的逻辑名是mybackupfileexec sp_addumpdevice disk,mybackupfile,e:datamybackupfile.baksql 执行差异备份时应注意一下几点:(1)若在上次完全数据库备份之后,数据库的某行被修改了,则执行差异备份至保存最

12、后一次的修改。(2)为了是差异备份设备与完全数据库备份设备区分开来,应使用不同的备份设备名。backup database xscjgl to disk=e:dataxscjgl.bak with differential创建一个命名的备份设备xscjgllogbk,并备份xscjgl数据库的事务日志exec sp_addumpdevice disk,xscjgllogbk,e:dataxscjgllog.bakbackup log xscjgl to xscjgllogbk如果数据库遭到破坏或者毁坏导致数据丢失,则可以使用备份设备进行备份:backup database xscjgl to

13、mybackupfile恢复数据库:restore database xscjgl from mybackupfilewith norecovery ,replacerestore log xscjgl from xscjgllogbk创建sql server登录名manager1,密码,manager2,密码,默认数据库设为xscjglcreate login manager1with password=542542,default_database=xscjglcreate login manager2with password=111222,default_database=xscjgl

14、使用sql server登录名manager1在xscjgl数据库中创建数据库用户名tao ,默认架构名使用dbo。 使用sql server登录名manager2在xscjgl数据库中创建数据库用户名su ,默认架构名使用dbo。create user tao for login manager1 with default_schema=dbocreate user su for login manager2 with default_schema=dbo 详细设计5.1 登录模块1.功能设计 在已经设计好的界面中的相应地方输入账号,密码,选择是学生还是老师。在以上的都填写完毕之后点击登录,

15、完成登录。学生的登录账号为学号,初始密码也为学号。教师的登录账号为教师号,初始密码也为教师号。用户可以在首次登录之后进行更改密码,以保证信息安全。2.界面设计 界面设计力求简洁,在简单的验证过身份之后即进入系统。登录界面没有做过多的身份认证,主要考虑到学生成绩管理系统是在学校内部使用,是在校内网,所以能登录的只是学校的老师或学生。界面顶部用的是带有华北科技学院学院的名字的图片。登录界面截图:3模块算法(或重要代码段)if(xsb.isSelected() try Connection con = DriverManager.getConnection(jdbc:sqlserver:/127.0

16、.0.1:1433;DatabaseName=xscjgl,sjs,1234); Statement stmt = con.createStatement(); ResultSet rs = stmt.executeQuery(exec student_info); while(rs.next() if(rs.getString(学号).equals(username) if(rs.getString(密码).equals(password) save.user=username; save.userpassword=password; JOptionPane.showMessageDialo

17、g(ss,rs.getString(姓名)+同学!您好!欢迎登录教师管理系统!); Students stu = new Students(); else JOptionPane.showMessageDialog(ss,登录失败); /处理完之后释放资源。 rs.close(); stmt.close(); /传说中的抛出异常。 catch (SQLException se) JOptionPane.showMessageDialog(ss,se.getMessage(); else if(tch.isSelected() try Connection con = DriverManager

18、.getConnection(jdbc:sqlserver:/127.0.0.1:1433;DatabaseName=xscjgl,sjs,1234); Statement stmt = con.createStatement(); String id = null; ResultSet rs = stmt.executeQuery(select * from TCH); while(rs.next() if(rs.getString(教师号).equals(username) if(rs.getString(密码).equals(password) JOptionPane.showMessa

19、geDialog(ss,rs.getString(姓名)+老师!您好!欢迎登录教师管理系统!); Teachers tch=new Teachers();/登陆成功 else JOptionPane.showMessageDialog(ss, 登录失败); 4调试与测试 学生成绩管理系统的界面部分是在数据库设计完成之后才开始进行的。数据库中保存着用户的数据,其中就包括用户的登录账号和密码。数据库建立成功之后面临的第一个大的问题就是eclipse和数据库的连接问题。在eclipse上编写代码的过程中,由于各个模块写的时间都比较长,所以遇到的问题都能够解决了,碰到大的自己解决不了的也都请教了同学。

20、其中有一个子程序是报错一直找不到主类,我调试了好长时间一直发现不了哪里出了问题,最后在请教张永真之后得到了答案。因为主类被一个子类包在了大括号里,所以程序一直无法找到主类,所以程序也就无法正常运行了。5.2 教师模块1.功能设计 教师模块实现的功能有录入学生的基本信息,录入学生的成绩,修改学生的成绩,修改教师的登录密码等。2.界面设计 教师界面: 添加学生的基本信息: 添加学生成绩: 修改学生成绩: 修改教师登录密码:3模块算法(或重要代码段) public void actionPerformed(ActionEvent e) if(e.getSource()=item1) AddMsg m

21、sg = new AddMsg(); else if(e.getSource()=item2) Addscore as = new Addscore(); else if(e.getSource()=item3) Updatescore as=new Updatescore(); else Genggai as=new Genggai(); 4调试与测试 教师模块在调试的过程中总是出先数据无法正常的存入数据库的现象,解决起来都比较耗时,如何处理好界面之间的跳转,处理起来确实考验人的耐心和毅力,好在问题都能解决。5.3 学生模块1.功能设计 学生成绩管理系统在学生界面的功能设计主要考虑学生的基本

22、信息查询,各科的成绩查询,修改学生的登录密码等。2.界面设计 学生界面: 查询学生信息:查询学生成绩:3模块算法(或重要代码段) public void actionPerformed(ActionEvent e) if(e.getSource()=Item1)/ Mima mima=new Mima(); else if(e.getSource()=Item2) Serch ser = new Serch(); else Score so = new Score(); 4调试与测试 主要的问题就是各个类之间的连接问题,如何在点击查询成绩按钮之后程序能自动跳转到查询成绩的界面类似这样的问题还是

23、比较麻烦的。小结和展望这次数据库的课程设计其实是做的比之前好的很多,起码我是这么认为的。之前的课程设计仅仅是做了一下数据库,就是那种单纯的做数据库,没有前台,没有界面。这次的数据库是之前的一次很大的提升。做了界面,在界面上也花了很多的功夫。因为自己不擅长编程,所以编程对我来说也花了很多的时间。几乎是一边在学习一边在做设计。当然这样进行的过程就是进步也是挺大的。不仅要考虑数据库的设计,界面的设计,更重要的是还要把这两部分结合在一起,良好的结合在一起,并且能够运行,这是最关键的地方。还好现在的网络发达,有不懂得地方就可以上网查询。实在有不懂得的地方还可以问老师,同学。他们都挺热衷于解答的。就这样,

24、一点点的测试,一点的修改。两个星期就这么的过去了,关于数据库的设计想了一些方案,但是很快的就发现不适用。可能是因为没有做过项目的缘故吧,总是不能最好的顾及到用户的体验,无法很好的知道用户想实现的功能是什么。不过还好这次做的学生成绩管理系统并没有什么大的难度,一些功能都可以想的到。没有遗漏什么大的功能。对于数据库的学习虽然已经结束了,但我想这还是不够的,这点理论知识显然不能应对社会上的挑战。我对数据库挺感兴趣的,我想在这一领域,真正的掌握知识,加油吧。参 考 文 献1 耿祥义, 张跃平. Java大学实用教程(第3版).电子工业出版社2郑阿奇,刘启芬,顾韶华,sql server使用教程(第3版

25、) 电子工业出版社附 录使用说明书用户根据自己的身份选择登录,如果你是学生,输入学号和密码,即可登录学生界面。在学生界面你可以查询自己的基本信息,查询各科的成绩,以及修改密码。查询成绩和基本信息的时候不需要输入密码。如果你是老师,输入你的教师号和登录密码,即可以进入学生成绩管理系统。在教师界面,你可以录入学生的基本信息,录入学生的成绩,修改学生的基本信息,以及修改密码。/登录界面import java.awt.*;import javax.swing.*;import java.awt.event.*;import java.sql.*;class Systems extends JFrame

26、 implements ActionListener private static final Component Teacherwindow = null; public static String user; public static String pass; static Systems ss; /创建一个JPanel面板。JPanel是一个轻量级容易。 JPanel panel = new JPanel(); JLabel label1 = new JLabel(登录账号:); JTextField name = new JTextField(); JLabel label2 = n

27、ew JLabel(密 码:); JPasswordField pwd = new JPasswordField(); JButton Enter = new JButton(登录); JButton Exit = new JButton(退出); / String url = E:mysqlQQ图片20131223120608.jpg; ButtonGroup bgp = new ButtonGroup(); / An implementation of a radio button - an item that can be / selected or deselected, and wh

28、ich displays its state to the user. / Used with a ButtonGroup object to create a group of buttons in which / only one button at a time can be selected. /创建一个单选项。JRadioButton为单选按钮。 JRadioButton xsb = new JRadioButton(学生); JRadioButton tch = new JRadioButton(教师); /201107024111 public Systems() /Create

29、s a new, initially invisible Frame with the specified title. super(登录系统); this.setResizable(false);/设置窗口大小不可调整。 this.setBounds(40,60,800,800); JLabel img = new JLabel(new ImageIcon(url); img.setBounds(0,0,500,125); panel.add(img); xsb.setBounds(165,210,70,20); tch.setBounds(265,210,70,20); /bgp为单选按钮。 bgp.add(xsb); bgp.add(tch); /想panel中添加xsb和tch单选按钮。 panel.add(xsb); panel.add(tch); Enter.setBounds(150,250,80,2

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1