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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

高级数据库技术课程设计报告.docx

1、高级数据库技术课程设计报告高级数据库技术课程设计报告1.设计目的和任务 综合运用ADO.NET 相关知识,设计一个具有实用价值的学生考试管理系统。 (1)巩固和加深对本课程基本知识的理解和掌握; (2)掌握C#编程和ADO.NET程序调试的基本技能; (3)掌握设计ADO.NET应用软件的基本思路和方法; (4)提高运用ADO.NET解决实际问题的能力; (5)培养撰写设计报告的能力。 2.开发环境2.1硬件环境笔记本电脑硬件概要CPU 英特尔 Genuine Intel(R) CPU T2130 1.86GHz主板 Wistron - 英特尔 945PM (Calistoga-PM) + I

2、CH7-M/U内存 金士顿 2G DDR2-SDRAM 666 MHz 显卡 nVIDIA GeForce Go 7200 (G72)主硬盘 希捷 120GB 声卡 英特尔 82801GB ICH7 - High Definition Audio B0网卡 英特尔 PRO/Wireless 3945ABG Network Connection (HP - RoW)2.2软件环境Microsoft Windows XP操作系统;Microsoft SQL Server 2005;Microsoft Visual Studio 2005;3.设计题目3.1题目名称学生考试管理系统3.2题目详细描述

3、1、登录界面 2、新用户注册 3、教师管理界面 4、管理员管理界面 5、学生在线考试 3.3功能要求登录界面 功能: 1) 用户对应相应的权限进行登录,分教员、学生、管理员。登录后根据选择的权限进入相应的界面; 2) 输入用户名框非空,密码框非空,权限选择判断; 3) 新学员用户注册。注册后需管理员激活才能登录。教师管理界面 功能(按菜单项说明): 1) 试题管理,子菜单如下: 增加试题; 查询试题:按科目查询试题; 试题列表:按难度查询试题列表,并可增加、修改试题。 2) 考试管理,子菜单如下: 生成试卷; 试卷管理:查看试卷信息、激活/取消试卷。 3) 成绩管理,按试卷名查寻成绩。要算出平

4、均分。管理员管理界面功能(按菜单项说明): 1) 用户管理,子菜单如下: 新建用户:新建学员用户,新建教员用户。 查询及修改学员。 用户信息列表,包括查询以及教员学员信息 2) 题库管理,管理试题库 学生在线考试 1) 维护个人信息 对个人信息进行查询, 修改2)在线答题。功能:可以选择已激活试卷答题。 在线评分。 保存考试成绩可供教师查询。4.相关技术及知识点ADO.NET提供了多种对象模型,比较典型的以下有五种,它们全部归类System.Data.SqlClient名称空间下。4.1 SqlConnection对象ADO.NET使用SqlConnection对象与SQL Server进行连

5、接。连接字符串的常用形式有两种:1.使用Windows集成安全身份认证, 例如:string connectionString =IntegratedSecurity=SSPI;Database=MySchool.mdf;Server=localhost;2.在连接字符串中指定服务器名、用户id、用户口令、数据库名等信息。 例如:string connectionString = server=localhost; uid=sa; pwd=123; database=MySchool.mdf;然后通过连接字符串直接创建SqlConnection对象,如SqlConnection conn =

6、new SqlConnection(connectionString);4.2 SqlCommand对象 在ADO.NET中,有两种操作数据库的方式:1.无连接的方式;2.保持连接的方式。不论哪种都可以通过SqlCommand对象提供的方法传递对数据库操作的命令,并返回命令执行结果。在保持连接的方式下操作数据库的一般步骤为:1.创建SqlConnection的实例;2.创建SqlCommand的实例;3.打开连接;4.执行命令;5.关闭连接。SqlCommand对象提供了多种完成对数据库操作的方法。常用有:1.ExecuteNonQuery该方法执行SQL语句的结果,但不返回命令执行的表数据,

7、仅返回操作所影响的行数。2.ExecuteReaderExecuteReader方法提供了只向前的、顺序的快速读取数据库中数据的方法。3.ExecuteScaler()该方法用于执行SELECT查询,得到的返回结果为一个值的情况,比如使用count函数求表中记录个数或者使用sum函数求和等。4.3 SqlDataAdapter对象 SqlDataAdapter对象通过无连接的方式完成数据库和本地DataSet之间的交互。使用这种方式操作数据库的一般步骤为:1.创建SqlConnection的实例;2.创建SqlDataAdapter的实例,需要的话,根据select语句生成其他SQL语句;3.

8、创建DataSet的实例;4.使用Fill方法将数据库中的表填充到DataSet的表中;5.利用DataGridView或者其他控件对象编辑或显示数据;6.需要的话,使用Update方法更新数据库。SqlDataAdapter对象通过SelectCommand、InsertCommand、UpdateCommand和DeleteCommand属性为后台数据库提供对应的操作命令,并传递需要的参数。一般情况下,只需要提供SELECT语句和连接字符串创建SqlDataAdapter对象,然后利用SqlCommandBuilder对象生成InsertCommand、UpdateCommand和Dele

9、teCommand属性。4.4 DataTable对象 ADO.NET可以在与数据库断开连接的方式下通过DataSet或DataTable对象进行数据处理,当需要更新数据时才重新与数据源进行连接,并更新数据源。DataTable对象表示保存在本机内存中的表,它提供了对表中行列数据对象的各种操作。可以直接将数据从数据库填充到DataTable对象中,也可以将DataTable对象添加到现有的DataSet对象中。在断开连接的方式下,DataSet对象提供了和关系数据库一样的关系数据模型,代码中可以直接访问DataSet对象中的DataTable对象,也可以添加、删除DataTable对象。1.

10、创建DataTable对象可以通过以下两种方式创建DataTable对象:1) 通过DataTable类的构造函数创建DataTable对象,例如:DataTable table = new DataTable();2) 通过DataSet的Tables对象的Add方法创建DataTable对象,例如:DataSet dataset = new DataSet();DataTable table = dataset.Tables.Add(MyTableName);2. 在DataTable对象中添加列在DataTable对象中添加列的最常用的方法是通过DataTable对象的Column属性中

11、的Add方法。添加后的每一列都是一个DataColumn对象。3. 设置DataTable对象的主键关系数据库中的表一般都有一个主键,用来惟一标识表中的每一行记录。通过DataTable对象的PrimaryKey属性可以设置Datatable的主键。主键可以是一个或者多个DataColumn对象组成的数组。例如:DataColumn key = new DataColumn1;/dt是一个DataTable对象key0 = dt.Columns0;dt.PrimaryKey = key;4. 在DataTable对象中创建行DataTable对象的每一行都是一个DataRow对象,所以创建行时

12、可以先利用DataTable对象的NewRow方法创建一个DataRow对象,并设置新行中各列的数据,然后利用Add方法将DataRow对象添加到表中5. 将SQL Server数据库中的表填充到DataTable中除了可以直接创建DataTable对象的行列信息外,也可以通过DateAdapter对象的Fill方法将SQL Server数据库中的表填充到DataTable对象中。4.5 DataSet对象1. 创建DataSet对象使用创建的DataSet对象可以完成各种数据操作,利用向导生成的数据库数据源是一个强类型的DataSet以及一对或多对强类型的DataTable和TableAda

13、pter的组合。类型化的DataSet是一个生成的类,是从.NET Framework的一般DataSet类衍生来的,但提供了已定义的架构以及特定于该架构的属性和方法。同时,对于DataSet中的每个表,还生成了特定于该DataSet的附加衍生类,而且每个类都为相关的表提供了特定的架构、属性和方法。当然,也可以直接创建一般的DataSet对象,例如:DataSet myDataset = new DataSet();2. 填充DataSet对象创建DataSet后,就可以使用SqlDataAdapter对象把数据导入到DataSet对象中,比如通过Fill方法将数据填充到DataSet中的某个

14、表中。5.设计与实现(包括每个设计点的文字描述,图表,关键代码) (该说明在最终报告里面要删除!)5.1登录界面在登录界面(图5-1)用户对应相应的权限选择用户类型进行登录,分教员、学生、管理员。登录后根据选择的权限进入相应的界面。输入用户名框非空,密码框非空,权限选择判断;登录界面还有新用户注册,同样是选择不同用户类型进行注册。注册后需管理员激活才能登录。还有一个就是找回密码,用户通过输入用户名和姓名等信息找回密码。 图5-1登录界面代码: if (ValidateInput() / 验证输入成功 string message = ; / 验证输入的密码 if (loginBll.Valid

15、ateUser(txtLoginId.Text.Trim(), txtLoginPwd.Text, cboLoginType.Text, ref message) / 记录登录用户名和登录类型 UserHelper.loginId = txtLoginId.Text; UserHelper.loginType = cboLoginType.Text; if (cboLoginType.Text = 教师) / 创建教员主窗体对象 TeacherForm teacherForm = new TeacherForm(); / 显示窗体 teacherForm.Show(); else if (cb

16、oLoginType.Text = 学生) StudentForm studentForm = new StudentForm(); studentForm.Show(); else AdminForm adminForm = new AdminForm(); adminForm.Show(); / 登录窗体隐藏 this.Visible = false; 5.2教师管理界面在教师管理界面(图5-2)中有以下菜单和按钮:*选择题目(图5-3):右键选择题目加入到新建的试卷中;*成绩管理(图5-4)选择不同的试卷进行查询,读取数据到DataSet,然后用DataSet中数据计算该试卷的平均分;也

17、可以直接修改DataSet中表的数据,然后保存。增加试题:先输入好题目,然后提交,将数据插入数据库中;还有一些其它的功能,查询试题:按科目查询试题;试题管理:按难度查询试题列表,并可增加、修改试题。试题列表,按难度查询试题列表,并可增加、修改试题然后保存,将数据保存到数据库; 图5-2 图5-3 图5-4教师管理界面代码:/ 点击时,打开新增试题窗体 private void tsmiAddQuestion_Click(object sender, EventArgs e) / 创建窗体对象 AddQuestionForm addQuestionForm = new AddQuestionFo

18、rm(); / 设置 MDI 主窗体 addQuestionForm.MdiParent = this; / 显示窗体 addQuestionForm.Show(); / 点击菜单中的“帮助”-”关于”,以模式窗口显示 About 窗体 private void tsmiAbout_Click(object sender, EventArgs e) AboutForm aboutForm = new AboutForm(); aboutForm.MdiParent = this; aboutForm.Show(); / 以模式窗口显示 / 窗体加载事件处理 private void Teach

19、erForm_Load(object sender, EventArgs e) / 设置状态栏标签显示的文字 lblTeacher.Text = string.Format(教员0登录了!, UserHelper.loginId); private void TeacherForm_FormClosed(object sender, FormClosedEventArgs e) Application.Exit(); private void btnSearchQuestion_Click(object sender, EventArgs e) CheckTitles CT = new Che

20、ckTitles(); CT.Show(); private void btnQuestionList_Click(object sender, EventArgs e) / 创建窗体对象 TestList tForm = new TestList(); / 设置 MDI 主窗体 tForm.MdiParent = this; / 显示窗体 tForm.Show(); 选择题目代码: /选择题目窗口 private void TestList_Load(object sender, EventArgs e) dataSet=getDataSetBll.GetAllQuestion(ref da

21、taAdapter); dataSet2 = getDataSetBll.GetSelectedQuestion(ref dataAdapter2, ExamId); dgvTest.DataSource =dataSet.TablesQuestion; txtExamName.Text = CreateTestForm.ExamName; ExamId = CreateTestForm.ExamId; /刷新 private void button1_Click_1(object sender, EventArgs e) dataSet.TablesQuestion.Clear(); dgv

22、Test.DataSource = getDataSetBll.GetQuestionByDifficulty(cboDifficulty.Text.Trim(), ref dataAdapter); /将选中的题目加入试卷中 private void tsmAddQuestion_Click(object sender, EventArgs e) string message=; int sum = dgvTest.SelectedCells.Count; for (int i = 0; i sum;i+) string QuestionId = dgvTest.SelectedCellsi

23、.Value.ToString(); message = createTestBll.AddQuestion(ExamId, QuestionId, ref ExamSum); txtExamSum.Text = ExamSum.ToString(); MessageBox.Show(message); /将选中的题目从试卷中删除 private void tsmDeleteQuestion_Click(object sender, EventArgs e) string message=; int sum = dgvTest.SelectedCells.Count; for (int i =

24、 0; i sum; i+) string QuestionId = dgvTest.SelectedCellsi.Value.ToString(); message = createTestBll.DeleteQuestion(ExamId, QuestionId, ref ExamSum); txtExamSum.Text = ExamSum.ToString(); MessageBox.Show(message); /已选择题目列表 private void btn_Click(object sender, EventArgs e) dataSet2.TablesQuestion.Cle

25、ar(); dataSet2 = getDataSetBll.GetSelectedQuestion(ref dataAdapter2,ExamId); dgvSelectedQuestion.DataSource = dataSet2.TablesQuestion; private void button3_Click(object sender, EventArgs e) this.Close(); 成绩管理代码:/成绩管理的窗口 private void TestGradeManageForm_Load(object sender, EventArgs e) ExamId = cboEx

26、amId.Text.ToString(); dataSet = getDataSetBll.GetScore(ref dataAdapter,ExamId); /加载examId foreach (DataRow row in dataSet.TablesScore.Rows) foreach(string item in cboExamId.Items) if (item.ToString().Equals(rowexamId.ToString() goto con; cboExamId.Items.Add(rowexamId.ToString(); con: ; dgvScore.Data

27、Source = dataSet.TablesScore; private void btnSearch_Click(object sender, EventArgs e) /查询成绩 ExamId = cboExamId.Text.ToString(); dataSet.TablesScore.Clear(); dataSet = getDataSetBll.GetScore(ref dataAdapter, ExamId); dgvScore.DataSource = dataSet.TablesScore; int sum = 0,i=0,avgScore=0; foreach (Dat

28、aRow row in dataSet.TablesScore.Rows) sum += int.Parse(rowscorevalue.ToString(); i+; if(i!=0) avgScore = sum / i; txtAvgScore.Text = avgScore.ToString(); /刷新 private void btnRefresh_Click(object sender, EventArgs e) dataSet.TablesScore.Clear(); dataSet = getDataSetBll.GetScore(ref dataAdapter, ExamI

29、d); /保存 private void btnSave_Click(object sender, EventArgs e) DialogResult result = MessageBox.Show(确定); if (result = DialogResult.OK) SqlCommandBuilder builder = new SqlCommandBuilder(dataAdapter); dataAdapter.Update(dataSet, Score); 5.3管理员管理界面管理员管理界面(图5-5):通过选择不同的菜单和按钮进入不同的界面,用户管理,其中有新建用户(新学员用户,新

30、建教员用户)。 查询及修改学员(图5-6):用DataSet读取数据到DataGridView。 用户信息列表,包括查询以及教员学员信息。 题库管理,管理试题库 。 图5-5 图5-6学员信息界面代码:/学员窗口 private void TestList_Load(object sender, EventArgs e) dataSet=StudentListBll.GetAllQuestion(ref dataAdapter); dgvTest.DataSource = dataSet.TablesStudent; /刷新 private void button1_Click(object sender, EventA

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

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