数据库系统概论课程设计.docx

上传人:b****5 文档编号:6751398 上传时间:2023-01-10 格式:DOCX 页数:47 大小:3.35MB
下载 相关 举报
数据库系统概论课程设计.docx_第1页
第1页 / 共47页
数据库系统概论课程设计.docx_第2页
第2页 / 共47页
数据库系统概论课程设计.docx_第3页
第3页 / 共47页
数据库系统概论课程设计.docx_第4页
第4页 / 共47页
数据库系统概论课程设计.docx_第5页
第5页 / 共47页
点击查看更多>>
下载资源
资源描述

数据库系统概论课程设计.docx

《数据库系统概论课程设计.docx》由会员分享,可在线阅读,更多相关《数据库系统概论课程设计.docx(47页珍藏版)》请在冰豆网上搜索。

数据库系统概论课程设计.docx

数据库系统概论课程设计

摘要

随着信息技术在教务管理上越来越深入而广泛的应用,教务管理系统的实施在技术上已逐步成熟。

教务管理系统是一个不断发展并创新的具有潜力的系统,任何一个学校要生存要发展,要高效率地把内部活动有机地组织起来,就必须建立与自身特点相适应的教务管理系统。

本文介绍了在VS2012C#.NET环境下采用“自上而下地总体规划,自下而上地应用开发”的策略开发一个简单的教务管理信息系统的过程。

通过根据本学校的教务管理,模仿了一套行之有效的计算机管理学生、教师和课程的方案。

文章介绍了教务管理系统的系统分析部分,包括可行性分析、业务流程分析等;系统设计部分主要介绍了系统功能设计和数据库设计及代码设计;系统实现部分说明了几个主要模块的算法,本系统界面友好,操作简单,比较实用。

 

关键词:

管理员管理、教师管理、学生管理、C#与SQLSever应用

 

教务管理系统

1.系统概述

此系统模拟了学校的教务管理系统,具有管理员、教师和学生的独自登陆界面,并分别为其服务。

1.1系统需求及分析

经过调查,要求系统具有一下几个基本功能:

(1)由于操作人员的计算机知识普遍较差,要求有良好的人机界面;

(2)由于该系统的使用对象多,要求有较好的权限管理;

(3)原始数据修改简单方便,支持多条件修改;

(4)方便的数据查询,支持多条件查询;

(5)在相应的权限下,删除数据方便简单,数据稳定性好;

因为此系统主要面对学校的教务管理人员、教师和学生,所以管理员具有增删改自己信息、教师信息、课程信息、学生信息的基本功能,教师要具有修改个人信息、学生成绩录入、修改和管理、课程的管理等基本功能,学生具有修改个人信息、查看成绩、选课情况等基本功能。

这些功能都在VS2010.NETC#语言和SQLSever2008数据库下可以实现。

1.2系统的功能简介

管理员:

管理员管理、教师管理、学生管理、课程管理、特殊管理;

窗体界面如下:

教师:

挂机、个人信息、个人课程、成绩管理;

窗体界面如下:

学生:

个人信息、个人课程、个人成绩;

窗体界面如下:

1.3系统开发目标

出于本系统是学校教务管理的一个综合性的系统,本系统的设计目标将最终定位于完成以上所述的系统主要业务的基本模型上。

 

2.系统设计

系统设计包括系统模块设计和数据库设计。

2.1系统模块设计

主要功能模块如图所示:

公共模块:

密码修改、用户登录

如图所示:

2.2数据库设计

数据库设计的任务是确定系统所需要的数据库。

数据库是表的集合,通常一个系统只需要一个数据库。

设计的任务是根据需求分析,确定数据库所包含的表及字段、表间的关系,然后具体确定表的结构,包括字段名、字段类型及宽度,需要的索引等。

根据对需求得到的数据结构进行分析,按数据输入输出的要求,确定表和表之间的关系,并进行验证、调整、修改、完善,使其能够实现用户对数据和功能的要求。

数据库在SQLSever2008下创建,数据库名为Infor_System_School。

2.2.1本项目根据分析确定系统要设置如下表:

1.User_admin表、User_Stu表和User_Teach表:

属性名

含义

数据类型

限制条件

User_ID

编号

Char(3)

PRIMARYKEY

User_name

姓名

Varchar(20)

NOTNULL

User_password

密码

Varchar(10)

NOTNULL

2.Admin表:

属性名

含义

数据类型

限制条件

Admin_no

编号

Char(3)

PRIMARYKEY

Admin_name

姓名

varchar(10)

NOTNULL

Admin_position

职务

varchar(10)

NOTNULL

Admin_sex

性别

char

(2)

NOTNULL

Admin_age

年龄

int

NOTNULL

Admin_tel

联系方式

char(11)

Admin_mail

邮箱

varchar(20)

Admin_addr

住址

varchar(50)

3.Student表

属性名

含义

数据类型

限制条件

Stu_no

学号

Char(9)

PRIMARYKEY

Stu_name

姓名

varchar(10)

NOTNULL

Stu_sex

性别

Char

(2)

NOTNULL

Stu_bir

出生日期

date

Stu_class

班级

varchar(10)

NOTNULL

Stu_dept

专业

varchar(20)

NOTNULL

Stu_prof

学院

varchar(20)

NOTNULL

Stu_tel

联系方式

Char(11)

Stu_addr

宿舍地址

varchar(6)

Stu_mail

邮箱

varchar(20)

Stu_rtime

入学时间

date

4.Teacher表:

属性名

含义

数据类型

限制条件

Teach_no

工号

Char(5)

PRIMARYKEY

Teach_name

姓名

varchar(10)

NOTNULL

Teach_photo

照片

varbinary(MAX)

Teach_sex

性别

Char

(2)

NOTNULL

Teach_bir

出生日期

date

Teach_prof

学院

varchar(20)

NOTNULL

Teach_ttime

入校时间

date

Teach_tel

联系方式

char(11)

Teach_mail

邮箱

varchar(20)

Teach_addr

住址

varchar(50)

5.Course表:

属性名

含义

数据类型

限制条件

Cou_no

课程号

Char(5)

PRIMARYKEY

Cou_name

课程名

varchar(20)

NOTNULL

Cou_redit

学分

float

NOTNULL

Cou_time

学时

int

NOTNULL

Cou_type

学科类型

varchar(4)

NOTNULL

6.TeachCou表:

属性名

含义

数据类型

限制条件

Cou_no

课程号

Char(5)

PRIMARYKEY

Teach_no

教师工号

Char(5)

PRIMARYKEY

7.Score表:

属性名

含义

数据类型

限制条件

Cou_no

课程号

Char(5)

PRIMARYKEY

Stu_no

学号

Char(9)

PRIMARYKEY

Teach_no

教师工号

Char(5)

PRIMARYKEY

grade

成绩

float

注:

各表内容见附录1.

2.2.2数据表间的逻辑关系

为了能使用户更直观地了解数据库中的个表之间的关系,可以通过建立关系图,如下图所示:

3.系统的代码实现

本系统采用的是C#语言和SQLSever数据库服务器。

3.1C#与SQLSever的基本介绍与连接

3.1.1SQLSever简介

SQLSever数据提供程序只能用于SQLSever,在System.Data.SqlCilent命名空间中实现。

3.1.2ADO.NET介绍

ADO(ActiveXDataObjects)是一个用于存取数据源的COM组件,用于实现访问关系或非关系数据库中的数据。

ADO为编程语言和统一数据访问方式OLEDB提供了一个中间层。

开发人员在访问数据库是只需要关心到数据库的连接,而不需要知道关系数据库是如何实现的。

ADO.NET提供了平台互用性和可伸缩的数据访问,支持对数据的松耦合访问,增强了对非连接编程模式的支持。

ADO.NET中主要包含的对象包括SqlConnection对象、Command对象、SqlDataReader对象、DataSet对象和SqlDataAdapter对象等。

此外,ADO.NET还提供了脱机访问模式,及提供了断开连接的数据访问模型,也就是说,首先连接数据库,获取需要的数据,然后断开与数据库的连接,在DataSet或DataTable组件中脱机处理数据,这位应用程序提供了很高的可伸缩性,因为该模型允许多个客户连接数据库,检索数据。

在Web应用程序中,这是很重要的,因为可能同时有成千上万个客户请求数据,这样,通过脱机访问模式,就可以在DataSet或DataTable组件中脱机处理数据,减少了对服务器端的压力。

3.1.3C#与SQLSever连接

在进行SQLSever数据库连接的时候,首先要使用数据库连接的提供者,因此在程序的开始要使用以下代码:

usingSystem.Data;

usingSystem.Data.SqlClient;

接下来要连接数据源,这需要使用连接字符串创建一个连接对象。

连接字符串中包含希望链接的数据库提供者名称、登录信息以及希望使用的数据库名称。

创建连接对象的代码如下:

stringsource="Server=SQLSever名称;InitialCatalog=数据库名称;IntegratedSecurity=SSPI;";

SqlConnectionconn=newSqlConnection(source);

这样,就有了一个为计算机和数据库配置的连接对象了,但是该对象还未激活,因此必须打开连接。

再有了对象之后就可以打开它,建立与数据库的连接conn.Open();如果Open方法未成功,那么就会抛出SqlException异常。

3.2系统中只要窗体和代码

3.2.1登录窗体

功能实现:

输入用户名和密码,登录教务管理系统。

窗体:

主要代码:

lab_error1.Text="";

lab_error2.Text="";

if(comboB_name.Text=="")

{

lab_error1.Text="用户名不能为空!

";

}

elseif(textB_password.Text=="")

{

lab_error2.Text="请输入密码!

";

}

else

{

try

{

stringsource="Server=姜梦龙-;InitialCatalog=Infor_System_School;IntegratedSecurity=SSPI;";

stringselect;

SqlConnectionconn=newSqlConnection(source);

conn.Open();

if(radioB_stu.Checked)

{

select="selectUser_ID,User_name,User_passwordfromUser_StuWhere[User_ID]='"+comboB_name.Text+"'AND[User_password]='"+textB_password.Text+"'";

}

elseif(radioB_teach.Checked)

{

select="selectUser_ID,User_name,User_passwordfromUser_TeachWhere[User_ID]='"+comboB_name.Text+"'AND[User_password]='"+textB_password.Text+"'";

}

else

{

select="selectUser_ID,User_name,User_passwordfromUser_adminWhere[User_ID]='"+comboB_name.Text+"'AND[User_password]='"+textB_password.Text+"'";

}

SqlCommandcmd=newSqlCommand(select,conn);

SqlDataReaderdr=cmd.ExecuteReader();

if(!

dr.HasRows)

{

textB_password.Text="";

MessageBox.Show("用户名或密码错误!

","错误提示:

",MessageBoxButtons.OK,MessageBoxIcon.Warning);

}

else

{

dr.Read();

stringname=dr.GetString

(1);

if(radioB_stu.Checked)

{

MessageBox.Show("欢迎"+name+"同学使用教务管理系统","提示:

");

this.Hide();

学生F=new学生();

F.Show();

}

elseif(radioB_teach.Checked)

{

MessageBox.Show("欢迎"+name+"教师使用教务管理系统","提示:

");

this.Hide();

教师F=new教师();

F.Show();

}

else

{

MessageBox.Show("欢迎"+name+"管理员使用教务管理系统","提示:

");

this.Hide();

管理员F=new管理员();

F.Show();

}

dr.Close();

}

conn.Close();

}

catch(Exceptionex)

{

MessageBox.Show(ex.Message);

}

}

3.2.2管理员窗体框架

功能实现:

管理员具有增加、查询、修改、注销管理员、教师、学生、课程,授课课程管理,还有特殊服务:

密码服务等基本功能。

窗体:

主要代码:

代码太多,只选其中一部分代码。

privatevoidbutton_save_导入_Click(objectsender,EventArgse)

{

SqlConnectionconn=newSqlConnection(source);

charsex;

if(radioB_男.Checked)

{

sex='男';

}

else

{

sex='女';

}

stringinsert_admin="insertintoAdminvalues('"+textB_no_导入.Text+"','"+textB_name_导入.Text+"','"+textB_posi_导入.Text+"','"+sex+"','"+textB_age_导入.Text+"','"+textB_tel_导入.Text+"','"+textB_mial_导入.Text+"','"+textB_addr_导入.Text+"')";

stringinsert_user="insertintoUser_adminvalues('"+textB_no_导入.Text+"','"+textB_name_导入.Text+"','"+123456+"')";

SqlCommandcmd_admin=newSqlCommand(insert_admin,conn);

SqlCommandcmd_user=newSqlCommand(insert_user,conn);

try

{

conn.Open();

cmd_admin.ExecuteNonQuery();

cmd_user.ExecuteNonQuery();

}

catch(Exceptionex)

{

MessageBox.Show(ex.Message);

MessageBox.Show("录入出现异常!

","提示",MessageBoxButtons.OK,MessageBoxIcon.Stop);

}

finally

{

conn.Close();

}

MessageBox.Show("录入成功!

","提示");

}

privatevoidbutton_查询_admin_Click(objectsender,EventArgse)

{

ds=newDataSet();

ds.Clear();

stringselect;

SqlConnectionconn=newSqlConnection(source);

conn.Open();

if(textB_查询_admin.Text=="")

{

select="selectdistinctAdmin_noAS编号,Admin_nameAS姓名,Admin_positionAS职务,Admin_sexAS性别,Admin_ageAS年龄,Admin_telAS联系方式,Admin_mailAS邮箱,Admin_addrAS住址fromAdmin";

}

elseif(radioB_编号_admin.Checked)

{

select="selectdistinctAdmin_noAS编号,Admin_nameAS姓名,Admin_positionAS职务,Admin_sexAS性别,Admin_ageAS年龄,Admin_telAS联系方式,Admin_mailAS邮箱,Admin_addrAS住址fromAdminWhereAdmin_no='"+textB_查询_admin.Text+"'";

}

elseif(radioB_姓名_admin.Checked)

{

select="selectdistinctAdmin_noAS编号,Admin_nameAS姓名,Admin_positionAS职务,Admin_sexAS性别,Admin_ageAS年龄,Admin_telAS联系方式,Admin_mailAS邮箱,Admin_addrAS住址fromAdminWhereAdmin_namelike'%"+textB_查询_admin.Text+"%'";

}

elseif(radioB_职务_admin.Checked)

{

select="selectdistinctAdmin_noAS编号,Admin_nameAS姓名,Admin_positionAS职务,Admin_sexAS性别,Admin_ageAS年龄,Admin_telAS联系方式,Admin_mailAS邮箱,Admin_addrAS住址fromAdminWhereAdmin_position='"+textB_查询_admin.Text+"'";

}

else

{

select="selectdistinctAdmin_noAS编号,Admin_nameAS姓名,Admin_positionAS职务,Admin_sexAS性别,Admin_ageAS年龄,Admin_telAS联系方式,Admin_mailAS邮箱,Admin_addrAS住址fromAdminWhereAdmin_age='"+textB_查询_admin.Text+"'";

}

da=newSqlDataAdapter(select,conn);

SqlCommandBuilderadmin=newSqlCommandBuilder(da);

da.Fill(ds);

this.DataGV_admin.DataSource=ds.Tables[0];

conn.Close();

}

privatevoidbutton_delete_admin_Click(objectsender,EventArgse)

{

ds=newDataSet();

ds.Clear();

stringselect,delete_admin,delete_user;

SqlConnectionconn=newSqlConnection(source);

if(textB_delete_admin.Text=="")

{

MessageBox.Show("请输入你要删除管理员的编号!

","提示",MessageBoxButtons.OK,MessageBoxIcon.Warning);

}

else

{

select="selectdistinctAdmin_noAS编号,Admin_nameAS姓名,Admin_positionAS职务,Admin_sexAS性别,Admin_ageAS年龄,Admin_telAS联系方式,Admin_mailAS邮箱,Admin_addrAS住址fromAdmin";

delete_admin="deletefromAdminWhereAdmin_no='"+textB_delete_admin.Text+"'";

delete_user="deletefromUser_adminWhereUser_ID='"+textB_delete_admin.Text+"'";

SqlCommandcmd_admin=newSqlCommand(delete_admin,conn);

SqlCommandcmd_user=newSqlCommand(delete_user,conn);

try

{

conn.Open();

cmd_admin.ExecuteNonQuery();

cmd_user.ExecuteNonQuery();

}

catch(Exceptionex)

{

MessageBox.Show(ex.Message);

MessageBox.Show("注销出现异常!

","提示",MessageBoxButtons.OK,MessageBoxIcon.Stop);

}

f

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 工程科技 > 建筑土木

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

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