数据库课程设计-学生选课系统.doc_第1页
数据库课程设计-学生选课系统.doc_第2页
数据库课程设计-学生选课系统.doc_第3页
数据库课程设计-学生选课系统.doc_第4页
数据库课程设计-学生选课系统.doc_第5页
免费预览已结束,剩余22页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

信息工程学院课程设计报告设计名称: 数据库课程设计 姓 名: 学 号:姓 名: 学 号:姓 名: 学 号: 专业班级: 软件工程 系 (院): 信息工程学院 设计时间: 201120012学年第一学期 设计地点: 数据库实验室 成绩: 数据库课程设计报告 第 26 页,共 27页一课程设计目的数据库课程设计是为数据库原理及应用课程而独立开设的实践性课程,对于巩固数据库知识,加强学生的实际动手能力和提高学生综合素质十分必要。通过本实验达到以下目的:(1) 培养学生具有C/S和B/S/S模式的数据库应用软件系统的设计和开发能力。(2) 熟练掌握一种数据库系统(如SQL SERVER)的使用。(3) 熟练掌握一种数据库应用软件开发工具(如POWERBUILDER 、ASP、VB.NET)的使用。(4) 通过设计实际的数据库系统应用课题,进一步熟悉数据库管理系统的操作技术,提高动手能力,提高分析问题和解决问题的能力。二课程设计任务与要求:1、任务:学生选课系统问题描述:1) 学校学生有一万多人。2) 每个学生都有学号、学生姓名、学生性别、学生年龄、所在系别等信息。3) 每门课程有课程号、课程名、学分、学期、学时。4) 学生可以选修多门课程,一门课程可以供多个学生选修。2、设计要求:1) 实现学生信息管理的信息添加、修改、删除。2) 实现课程信息管理的信息添加、修改、删除。3) 实现对所有学生选课管理的选课、查询。4) 能够按学号、课程号查询学生的选课信息。5) 能够按查询值查询。6)设计一完整的数据库。要求掌握数据库的设计的每个步骤;掌握数据设计各阶段的输入、输出、设计环境、目标和方法;熟练的使用SQL语言实现数据库以及数据库重要对象的建立、应用和维护。三课程设计说明书1 需求分析(1)数据需求学生选课信息管理系统需要完成功能主要有:用户登录窗体界面,包括用户名和密码。学生选课信息管理系统窗体界面包含学生信息管理、课程信息管理、选课信息管理和退出本系统,点击子系统可以进入各个模块。学生信息管理窗体有添加、修改、删除、退出的功能,包括学生学号、姓名、性别、年龄、所在系部。课程信息管理窗体有添加、修改、删除、退出的功能,包括课程编号、课程名、学分、学期、学时。学生选课与选课信息查询窗体有选课、查询与退出的功能,选课包括选择学生与选择课程,选课查询包括查询内容与查询值。(2)事务需求在登录窗体部分,要求:可以输入用户名和密码进入系统学生选课信息管理系统主窗体。在学生选课信息管理系统的主窗体部分,要求:可以执行点击学生信息管理、课程信息管理、选课信息管理和退出本系统按钮进入的各个子系统操作。在学生信息管理部分,要求: a.可以浏览学生信息。b.可以对学生信息进行添加、修改、删除操作。在课程信息管理部分,要求:a.可以浏览课程信息。b.对课程信息可添加、修改、删除操作。在学生选课与选课信息查询部分,要求:a.显示当前数据库中选课信息情况。b.对学生选课与选课信息查询有选课、查询与退出操作。c.对学生选课信息有查询操作。 (3)关系模式(1) 登录(用户名,密码,用户分类)(2) 学生信息(学生学号,姓名,性别,年龄,所在系部)(3) 课程信息(课程编号,课程名,学分,学期,学时)(4) 学生选课(学生学号,课程编号,成绩)(5) 选课信息查询(学生学号, 课程编号)(4)数据流程图(DFD)通过对系统需求的调查分析,细化软件功能,把系统划分为四个子系统,明确每个子系统所要完的主要逻辑功能,采用以图形的方式描绘数据在系统中流动和处理。学生选课管理系统学生管理员学生信息选课信息选课信息息课程信息息学生学生图1-1顶层数据流图F4P3D1F5课程信息学生信息P4D2D3D4登 录P1选课查询P2F2F1F3P数据流数据处理D数据存储F图1-2一层数据流图注:D1选课信息数据库D2 学生信息数据库 P2.1选择查询F2.1F2P2.2直接选课D1P2.3多条件查询F3F2.2D3 用户登录数据库D4课程信息数据库F1 登录信息F2,F3选课信息F4 课程管理信息F5 学生信息图1-3二层数据流图F4P3.2添 加F4D4P3.1课程P3.3修改F4F4P3.4删除图1-4二层数据流图P4.2添 加F5P4.1学生信息P4.3修改D3P4.4删除图1-5二层数据流图(5)数据字典 为了使各数据流,数据处理过程,存储过程不能反映其中的数据成,数据项目,数据特性,所以用数据字典来对数据流图中的各成份进行具体的定义,为系统的分析,设计及以后的实现提供供有关元素一致性定义和详细的描述:数据流字典数据流名称:用户登录 标志符:F1别名:无来源:用户去向:查询处理过程(P2、P3、P4)数据组成:用户名+密码数据流名称:选课查询 标志符:F2别名:无来源:学生去向:查询处理过程(P2)数据组成:选择学生|选择课程数据流名称:直接选课 标志符:F2.1别名:无来源:学生去向: 直接查询处理过程(P2.2)数据组成:选择学生|选择课程数据流名称:多条件查询 标志符:F2.2别名:无来源:学生去向: 多条件查询处理过程(P2.3) 数据组成:学号|课程号|查询值 数据流名称:课程信息 标志符:F4别名:无来源:学生去向: 课程信息处理过程(P3)数据组成:课程编号|课程名|学期|学时|学分数据流名称:课程添加 标志符:F4别名:无来源:管理员去向: 查询处理过程(P3.2)数据组成:课程编号|课程名|学期|学时|学分数据流名称:课程修改 标志符:F4别名:无来源:管理员去向:查询处理过程(P3.3)数据组成:课程编号|课程名|学期|学时|学分数据流名称:课程删除 标志符:F6.2别名:无来源:管理员去向: 课程管理处理过程(P4.3)数据组成:课程编号|课程名|学期|学时|学分数据流名称:学生管理信息 标志符:F5别名:无来源:管理员去向:学生管理处理过程(P4)数据组成:学号|姓名|性别|年龄|所在系数据流名称:学生信息添加 标志符:F5别名:无来源:管理员去向:学生管理处理过程(P4.2)数据组成:学号|姓名|性别|年龄|所在系数据流名称:学生信息修改 标志符:F5别名:无来源:管理员去向:学生管理处理过程(P4.3)数据组成:学号|姓名|性别|年龄|所在系数据存储字典:数据存储名称:选课信息数据库 标志符:D1描述:选课信息资料流入数据流:F2涉及处理: P2.2,P2.3数据组成:学号+课程号+成绩数据存储名称:学生信息数据库 标志符:D2描述:学生信息资料流入数据流:F5,F4涉及处理:P2.2,P2.3,P3.2数据组成:学号+姓名+性别+年龄+所在系数据存储名称:用户登录数据库 标志符:D3描述:用户登录资料流入数据流:F5涉及处理:P4.2,P4.3,P4.4数据组成:用户名+密码数据存储名称:课程信息数据库 标志符:D4描述:课程信息资料流入数据流:F4涉及处理:P3.2,P3.3,P3.4数据组成:课程编号+课程名+学期+学时+学分 数据处理字典:数据处理名称:用户登录 标志符:P1处理定义:登录系统 激发条件:所输入的用户名和密码正确输入:F1输出:F2,F5数据处理名称:选课查询 标志符:P2处理定义:查询选课信息 激发条件:所输入图书信息找到输入:F2输出:F3数据处理名称:查询选择 标志符:P2.1处理定义:选择查询方式 激发条件:已选择查询方式输入:F2输出:F2.1,F2.2数据处理名称:多条件查询 标志符:P2.3处理定义:查询选课信息 激发条件:所输入选课信息找到输入:F2.2输出:F3数据处理名称:直接查询 标志符:P2.2处理定义:直接查询选课信息 激发条件:所输入选课信息找到输入:F2.1输出:F3数据处理名称:课程信息 标志符:P3处理定义:管理课程信息激发条件:选择管理子功能输入:F4输出:D4数据处理名称:课程添加 标志符:P3.1处理定义:添加课程信息 激发条件:课程号输入:F4.1输出:D4数据处理名称:课程修改 标志符:P3.2处理定义:修改课程信息激发条件:课程号输入:F4.2输出:D4数据处理名称:课程删除 标志符:P3.2处理定义:删除课程信息 激发条件:课程号输入:F4.3输出:D4数据处理名称:学生信息 标志符:P4处理定义:管理学生信息 激发条件:选择管理子功能输入:F5输出:D3数据处理名称:学生添加 标志符:P4.1处理定义:添加学生信息 激发条件:学号输入:F5.1输出:D3数据处理名称:学生修改 标志符:P4.2处理定义:修改学生信息激发条件:学号输入:F5.2输出:D3数据处理名称:学生删除 标志符:P4.3处理定义:删除学生信息激发条件:学号输入:F5.3输出:D32 概要设计(1)实体图及E-R图根据1)所要实现的功能设计,可能建立它们之间的关系,进而实现逻辑结构功能。学生选课信息管理系统可以划分的实体有:用户登录实体、学生信息实体、课程信息实体、学生选课信息实体、学生选课查询信息实体。用E-R图一一描述这些实体。用户登录用户名密码用户登录实体图:图2-1用户登录实体及其属性图学生信息学号所在系别学生年龄学生性别学生姓名学生信息实体图:图2-2学生信息实体及其属性图课程信息课程号课程名学分学期学时课程信息实体图图2-3课程信息实体及其属性图选课信息学号课程号成绩选课信息实体图图2-4选课信息实体及其属性图总的E-R图: 管理员管理管理学生课程查询选课选修11m1mmmn图2-5实体及联系图(2)关系图图-6数据库存表关系图3逻辑设计表3-1 用户登录信息表表中列名数据类型可否为空说明userNamechar(16)not null(主键)用户名称userPasswordchar(16)not null密码表3-2学生信息表表中列名数据类型可否为空说明Snochar(10)not null(主键)学号Snamechar(8)not null姓名Ssexchar(2)null性别Sageintnull年龄Sdeptchar(20)null所在系别表3-3课程信息表表中列名数据类型可否为空说明Cnochar(10)Not null(主键)课程号Cnamechar(20)Not null课程名称Ccredtintnull学分Csemesterintnull学期CperiodintNull学时 表3-4选课信息表表中列名数据类型可否为空说明Snochar(10)Not null(外主键)学生学号Cnochar(10)Not null(外主键)课程号gradeintnull成绩表3-5查询选课信息表表中列名数据类型可否为空说明Snochar(10)Not null(外主键)学生学号Cnochar(10)Not null(外主键)课程号4 物理设计数据库物理设计阶段的任务是根据具体计算机系统(DBMS和硬件等)的特点,为给定的数据库模型确定合理的存储结构和存取方法。所谓的“合理”主要有两个含义:一个是要使设计出的物理数据库占用较少的存储空间,另一个对数据库的操作具有尽可能高的速度。主要体现在后者。(1)建立索引:对tb1_Student表在Sno属性列上建立聚集索引,在Sname属性列上建立非聚集索引。对tb1_Course表在Cno上建立聚集索引,在Cname、 Ccredt、Csemester、Cperiod上建立非聚集索引。对tb1_SC表在Sno、Cno上建立聚集索引,在Grade上建立非聚集索引对tb1_User表在userName上建立聚集索引。(2)存储结构确定数据库的存储结构主要指确定数据的存放位置和存储结构,包括确定关系、索引、日志、备份等的存储安排及存储结构,以及确定系统存储参数的配置。 将日志文件和数据库对象(表、索引等)分别放在不同的磁盘可以改进系统的性能。所以系统将日志文件和数据文件存放在不同磁盘上。5数据库建立(1)创建数据库create database SelectCourseon(name= SelectCourse _data,filename=d: SelectCourse _data.mdf, size=5MB,maxsize=20MB,filegrowth=2MB)log on(name= SelectCourse _log,filename=d: SelectCourse _log.ldf, size=1MB,maxsize=20MB,filegrowth=20%)(2)学生信息表建立use SelectCoursegocreate table tb1_Student(Sno char(5) primary key,sname char(20) unique,Ssex char(1),Sage int,Sdept char(15); go(3)课程信息表建立create table tb1_Course(Cno char(5),Cname char(10),Grade char(1),Primary key (Cno);(4)选课表建立create table tb1_SC(Sno char(5),Cno char(5),Grade int,Primary key(Sno,Cno),Foreign key(Sno)References Student(Sno),Foreign key(Cno)References Course(Cno);(5)索引的创建USE SelectCourseGOALTER TABLE dbo.tb1_Student ADD CONSTRAINT PK_tbl_Student PRIMARY KEY CLUSTERED (Sno ASC)WITH (PAD_INDEX = OFF, SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, ONLINE = OFF) ON PRIMARY6数据初始化(1)将学生信息加入表tb1_Student中insert into tb1_Student values(11001,李勇,男,20,CS)insert into tb1_Student values(11002,刘晨,男,19,CS)insert into tb1_Student values(11003,王敏,女,18,MA)insert into tb1_Student values(11004,张立,男,20,IS)(2)将课程信息加入tb1_Course表中insert into tb1_Course values(1,数据库,4);insert into tb1_Course values(2,数学,2);insert into tb1_Course values(3,信息系统,4);insert into tb1_Course values(4,操作系统,3);insert into tb1_Course values(5,数据结构,4);insert into tb1_Course values(6,数据处理,2);insert into tb1_Course values(7,C语言,4); (3)将选课信息加入tb1_SC表中insert into tb1_SC values(11001,1,92);insert into tb1_SC values(11001,2,85);insert into tb1_SC values(11001,3,92);insert into tb1_SC values(11002,2,88);insert into tb1_SC values(11002,3,90);7 数据库用户权限管理该系统设置两种类型的用户(1) 管理员(superadministrator) 即管理员拥有所有的权限。(2) 学生(student):可以对课程进行选课、查看自己的选课信息以及自己的学生信息。8、建立触发器,存储过程-此代码主要是实现新建一存储过程,该存储过程的名字为qchengji,其功能是按给定的学生姓名和课程名从SC表中查询该生所选该课程的成绩。create procedure qchengjisname_in char(8),cname_in char(20),score_out int outputasbeginselect score_out=grade from tb1_Student,tb1_Course,tb1_SCwhere tb1_Student.Sno=tb1_SC.Sno and tb1_Course.Cno=tb1_SC.Cno and Sname=sname_in and Cname=cname_inendGodeclare Sname_in char(8),Cname_in char(20),Score_out intselect Sname_in=杨美丽,Cname_in=cs11exec qchengji Sname_in,Cname_in,Score_out outputprint Sname_inprint Cname_inprint Score_outgo-此代码主要是实现新建一存储过程,该存储过程的名字为cjcx,其功能是按给定的学号和课程号从SC表中查询该生所选该课程的成绩。create procedure cjcxsno_in char(8),cno_in char(10),score_out int outputasbeginselect score_out=grade from tb1_SCwhere tb1_SC.Sno=sno_in and tb1_SC.Cno=cno_inendgodeclare Sno_in char(8),Cno_in char(10),Score_out intselect Sno_in=1134160201,Cno_in=cs11exec cjcx Sno_in,Cno_in,Score_out outputprint Sno_inprint Cno_inprint Score_out-此代码主要是实现新建一触发器,该触发器的名字为score_sc_tri,其功能是对输入的成绩进行合法性检查,即确保输入的成绩在0-100之间。create trigger score_sc_trion tb1_SC for insert,updateasdeclare score_read intselect score_read=grade from insertedif score_read=0 and score_read0rollback transactionend9 系统实现(1) 系统功能模块图:系统功能模块图如图10-1学生选课系统用户登录学生信息管理课程信息管理选课信息管理图9-1系统功能模块图四个模块的功能如下:登录模块: 可以实现一般用户和管理员登录管理学生信息管理:主要用于学生信息管理,其中管理员可以对学生信息进行添加、修改、删除操作。学生可以查看自己的学生信息。课程信息管理: 主要是课程的信息添加、修改、删除。选课信息管理:学生选课与选课信息查询窗体有选课、查询与退出的功能,选课包括选择学生与选择课程,选课查询包括查询内容与查询值。(2) 前台开发平台的选择:C#.NET(3) C#.NET与数据库的连接ADO.NET是C#.NET访问数据库的主要方式。ADO.NET的数据访问方式ADO.NET 的数据存取API 提供3 种数据访问方式: a)通过ODBC 相连,访问支持早期ODBC 协议的数据库。b)通过OLEDB 相连,访问SQL Server6.5, MicrosoftAccess, Oracle 或者其他有提供OLE DB 连接能力的数据库c)使用SqlConnection 直接与SQL Server7.0以及SQL Server2005 相连C#.NET访问数据库的具体过程a)创建数据库连接ADO.NET 中使用sqlConnection 类对SQL Server7.0 以及更高版本进行连接, 这个类的构造函数接受一个可选参数,称为连接字符串, 该字符串用于定义正在连接的数据库的类型、位置以及其他信息,这些属性用分号分隔,通常该字符串包含如下信息:Data Source 特性: 指定SQL Server 数据库所在计算机名称; Initial Catalog 特性: 指定连接的SQL Server 数据库的名称; User ID 和Pass-Word 特性: 指定用SQL SERVER登录方式的有效帐户名和密码或设置为:Integrated Security=True设置为Windows 登录方式。b ) 填充数据创建数据源连接以后,接下来创建数据适配器,适配器在创建过程中需要向其传递两个要素:用于包含结构化查询语句的数据描述和用于指明数据库连接信息的连接描述,创建后可利用Fill 方法,将所需的数据填充在一个数据集(DataSet)中。c ) 关闭数据库的连接由于DataSet采用是断开连接的方式,所以当把数据填充到数据集后即可断开与数据库的连接。 d) 为控件指定数据源数据填充到数据集后,要在窗体上显示出来,则必须把相应的数据表绑定到数据控件上。具体实现代码如下:public SqlConnection dataConnection = new SqlConnection(); public SqlDataAdapter dataAdapter; public DataSet dataSet = new DataSet(); string connstr = server=PC-200906200558SQLEXPRESS;database=SelectCourse;integrated security=SSPI; public DataSet GetDataFormDB(string sqlStr) try dataConnection.ConnectionString = connstr; dataAdapter = new SqlDataAdapter(sqlStr, dataConnection); dataSet.Clear(); dataAdapter.Fill(dataSet); dataConnection.Close(); catch (Exception ex) MessageBox.Show(ex.Message); dataConnection.Close(); if (dataSet.Tables0.Rows.Count != 0) return dataSet; else return null;public bool UpdateDB(string sqlStr) SqlConnection sqlConn = new SqlConnection(connstr); try SqlCommand cmdTable = new SqlCommand(sqlStr, sqlConn); cmdTable.CommandType = CommandType.Text; sqlConn.Open(); cmdTable.ExecuteNonQuery(); sqlConn.Close(); return true; catch (Exception ex) MessageBox.Show(ex.Message); return false; (4) 学生选课信息管理模块的实现学生选课信息管理系统登录界面如图10-2 图9-2学生选课信息管理系统登录界面图学生选课信息管理系统主界面如图10-3图9-3 学生选课信息管理系统主界面学生信息管理运行界面如图10-4 图9-4学生信息管理运行界面下面给出学生信息管理界面的主要代码: private void frmStudent_Load(object sender, EventArgs e) try ObjClose(); String sqlStr; DataBase db = new DataBase(); DataSet ds = new DataSet(); sqlStr = select * from tb1_Student; ds = db.GetDataFormDB(sqlStr); if (ds = null) MessageBox.Show(没有任何学生纪录); else dgrdvStudent.DataSource = ds.Tables0; dgrdvStudent_RowHeaderMouseClick(null, null); catch (Exception ex) MessageBox.Show(ex.Message); private void button1_Click(object sender, EventArgs e) try if (button1.Text.Trim() = 添加) button1.Text = 确定; ObjOpen(); Clear(); button2.Enabled = false; button3.Enabled = false; button4.Enabled = false; else button1.Text = 添加; if (textBox1.Text.Trim() != null & textBox2.Text.Trim() != null) string sqlStr; sqlStr = insert into tb1_Student values( + textBox1.Text.Trim() + , + textBox2.Text.Trim() + , + comboBox1.Text.Trim() + , + textBox3.Text.Trim() + , + textBox4.Text.Trim() + ); DataBase db = new DataBase(); bool b; b = db.UpdateDB(sqlStr); if (b = true) if (MessageBox.Show(添加成功!继续添加吗?, 添加学生, MessageBoxButtons.YesNo, MessageBoxIcon.Question, MessageBoxDefaultButton.Button1) = DialogResult.Yes) Clear(); ObjOpen(); button1.Text = 确定; else ObjClose(); button2.Enabled = true; button3.Enabled = true; button4.Enabled = true; dgrdvStudent.Enabled = true; else goto exit; else MessageBox.Show(学号与姓名不能为空); textBox1.Focus(); button1.Text = 确定; RefreshData(); textBox1.SelectAll(); catch (Exception ex) MessageBox.Show(ex.Message); Clear(); ObjClose(); dgrdvStudent.Enabled = false; exit: ; 课程信息运行界面如图10-5所示: 图9-5课程信息运行界面下面给出课程信息管理界面的主要程序代码:pr

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论