1、学生管理系统详细设计说明书第三组(2008/7)目 录1程序结构31.1程序结构31。2命名空间规范31。3程序通用名词规范42模块结构42。1学生信息管理模块42.2老师信息管理模块52。3 班级管理模块52。4 课程管理模块52.5 成绩管理模块62。6 帐号管理模块63模块功能详解73.1 学生信息管理模块73。2 教师信息管理模块73。3 班级管理模块83.4 课程管理模块83。5 成绩管理模块93.6 帐号管理模块104界面样式104。1 登录界面104.2用户管理114。3教师信息管理124.4学生信息管理134。5课程管理144.6成绩管理144。7班级管理155模型类设计155
2、。1用户模型设计155。2学生模型设计165.3教师模型设计165.4班级模型设计175。5成绩模型设计175。6课程模型设计176功能类设计176。1用户登录功能类186。2用户管理功能类186.3学生信息管理功能类196.4教师信息管理功能类206。5班级管理功能类226.6成绩管理功能类236.7课程信息管理功能类247数据库设计257.1用户管理模块257.2学生信息管理模块257。3老师信息管理模块257。4班级管理模块267.5成绩管理模块267.6课程信息管理模块267.7 班级课程277。9教师班级277。9 教师课程271程序结构1。1程序结构1。2命名空间规范主要类的命名空
3、间用途Model数据库模型类Manage数据库功能类StudentManage管理系统界面1。3程序通用名词规范模型类跟表同名,例如:Student功能类跟表同名,例如Student界面的命名以功能开头,后面跟上Form,例如AddStuForm添加的方法以Add开头,例如AddStu修改的方法以Modify开头,例如ModifyStu删除的方法以Del开头,例如DelStu查询的方法以Search开头,例如SearchStu有条件查询,用Get。.By,如跟据一个id号获得一行记录的模型类用GetModelById ,Model是模型类名。2模块结构2。1学生信息管理模块2。2老师信息管理模
4、块2。3 班级管理模块2.4 课程管理模块2。5 成绩管理模块2。6 帐号管理模块3模块功能详解3.1 学生信息管理模块3.1。1 管理员 3.1。1.1 增加学生 可以增加学生编号、姓名、性别、出生日期、入学日期、所在班级、电话号码、住址、备注3。1.1。2 删除学生 可以删除学生的所有信息3。1。1.3 修改学生信息 可对所有学生的资料进行修改3.1。1。4 查询学生信息a) 查询所有学生的一切信息,点击查询按钮则列出全部学生的基本信息包括学生编号、学生姓名、性别、入学日期、所在班级等 b) 模糊查询 根据学生编号、学生姓名、所在班级进行模糊查询,列出符合条件的所有学生的基本信息包括学生编
5、号、学生姓名、性别、入学日期、所在班级等3。1。2教师3.1。2.1 查询学生信息a) 查询所有学生的信息 点击查询按钮则列出所教学生的基本信息包括学生编号、学生姓名、性别、入学日期、所在班级等b) 模糊查询 根据学生编号、学生姓名、所在班级进行模糊查询,列出符合条件的所教学生的基本信息包括学生编号、学生姓名、性别、入学日期、所在班级等3.1。3学生3.1。3。1 查询信息 a) 个人信息查询 可查询自己的全部信息b) 本班学生信息查询 查询本班学生的基本信息学生编号、姓名、性别、所在班级、入学日期、个人说明等 3.2 教师信息管理模块3。2.1 管理员 3。2。1.1 增加教师 增加教师的编
6、号、姓名、性别、出生日期、学历、职称、所授课程、备注3.2.1。2 删除教师 可以删除教师的所有信息3。2.1.3 修改教师信息 可以修改老师的基本信息,包括教师编号、姓名、性别、出生日期、学历、职称、所授课程、备注3。2。1。4 查询教师信息 a) 查询所有教师的一切信息 点击查询按钮则列出全部教师的基本信息包括教师编号、教师姓名、性别、籍贯、所授课程等b) 模糊查询 根据教师编号、教师姓名进行模糊查询,列出符合条件的所有教师的基本信息包括教师编号、教师姓名、性别、所授课程等 3.2。1。5 增加教师职务 增加教师所教课程,所教班级记录3.2。2 教师3.2.2.1查询信息a) 查询个人信息
7、 教师可查询自己的所有信息b) 查询全部教师 查询所有教师的基本信息,点击查询按钮则列出全部教师的基本信息包括教师编号、教师姓名、性别、所授课程等c) 模糊查询 根据教师编号、教师姓名进行模糊查询,列出符合条件的所有教师的基本信息包括教师编号、教师姓名、性别、所授课程等 3。2.3 学生3。2。3。1 查询教师信息a) 查询所有教师的一切信息 点击查询按钮则列出全部授课教师的基本信息包括教师编号、教师姓名、性别、籍贯、所授课程等b) 模糊查询 根据教师编号、教师姓名进行模糊查询,列出符合条件的授课教师的基本信息包括教师编号、教师姓名、性别、所授课程等 3。3 班级管理模块3.3。1 管理员 3
8、.3。1。1 增加班级 增加班级的编号、班级名称3。3。1.2 删除班级 可删除班级所有信息3。3。1.3 修改班级信息 可修改班级所有信息3。3。1。4 查询班级信息a) 查询所有班级 点击可得到全部班级列表,包括班级编号、班级名b) 联合查询 根据班级编号、班级名进行模糊查询,得到满足条件的班级列表,包括班级编号、班级名3。3.2教师3.3.2。1 查询班级信息a) 查询全部授课班级 查询可得到所授课班级的列表,包括班级编号、班级名、班级课程b) 联合查询输入班级编号、班级名进行联合查询,得到满足条件的班级列表,包括班级编号、班级名、班级人数3。4 课程管理模块3.4。1 管理员3.4.1
9、。1 增加课程 增加课程编号、课程名、学分3。4。1。2 删除课程 删除课程编号、课程名、学分3。4。1.3 查询课程信息a) 查询全部课程 得到全部课程信息列表,包括课程编号、课程名、学分b) 联合查询输入课程编号、课程名进行联合查询得到符合条件的课程信息列表,包括课程编号、课程名、学分3。4.1。4 修改课程信息 修改课程的编号、课程名称、学分3。4。2 教师3。4。2。1 查询课程信息a) 查询全部所授课程 得到全部课程信息列表,包括课程编号、课程名、学分b) 联合查询 输入课程编号、课程名进行联合查询得到符合条件的课程信息列表,包括课程编号、课程名、学分3。4.3 学生3。4.3。1
10、查询课程信息a) 查询全部所学课程 得到全部课程信息列表,包括课程编号、课程名、学分b) 联合查询 输入课程编号、课程名进行联合查询得到符合条件的课程信息列表,包括课程编号、课程名、学分3.5 成绩管理模块3。5。1 管理员3。5。1。1 录入成绩 录入学生编号、课程编号、分数3。5。1。2 删除成绩 删除学生编号、课程编号、分数3。5。1.3 修改成绩 修改学生编号、课程编号、分数3。5。1。4 查询成绩a) 查询全部成绩 得到全部成绩信息列表,包括学生编号、学生姓名、所在班级、课程编号、课程名、分数b) 联合查询 根据学生编号、课程编号、教师编号、班级编号进行联合查询,得到满足条件的成绩信
11、息列表.3。5。2 教师3。5.2.1 查询成绩a) 查询所教学生成绩 得到全部所教所教学生的成绩信息列表,包括学生编号、学生姓名、所在班级、课程编号、课程名、分数b) 联合查询 根据学生编号、课程编号、教师编号、班级编号进行联合查询,得到满足条件的成绩信息列表。3.5。3 学生3。5.3。1 查询成绩a) 查询全部成绩 可以得到自己全部所学课程的成绩信息列表,包括编号、姓名、课程编号、课程名、学分.b) 联合查询 根据学生编号、课程编号、教师编号、班级编号进行联合查询,得到满足条件的成绩信息列表。 3。6 帐号管理模块3。6。1 管理员3。6。1。1查询用户 管理员可以查询所有用户的信息3.
12、6。1.2密码管理 管理员可以修改所有教师和学生的密码3。6。1。3 设置用户权限 设置不同的用户权限,当为不同用户登陆时显示不同的登陆界面3.6。2 教师 3.6.2.1 密码管理 教师可修改自己的密码3.6。3 学生 3。6。3.1 密码管理 学生可修改自己的密码4界面样式4。1 登录界面4。2用户管理4.3教师信息管理4。4学生信息管理4。5课程管理4。6成绩管理4。7班级管理5模型类设计命名空间类名说明ModelLogin登陆Student学生信息Teacher教师信息Class班级信息Score成绩信息Course课程信息User用户管理Class_Course班级课程Teacher
13、_Class教师班级Teacher_Course教师课程5。1用户模型设计Users名称中文名称类型控制域说明UserId用户idintPublicUserName用户名stringPublicPassWord密码stringPublicRights权限intPublicType删除标识intPublic为0时表示该生被删除5.2学生模型设计Student名称中文名称类型控制域说明StuId学生IdintPublicStuNo学生编号stringPublicStuName姓名StringPublicClassId班级IdintPublicSex性别StringPublicBirthDate出生
14、日期DateTimePublicEntranceTime入学时间datatimePublicStuTel电话号码stringPublicStuAddress住址stringPublicRemark备注stringPublicType删除标识intPublic为0时表示该生被删除5。3教师模型设计Teacher名称中文名称类型控制域说明TeaId教师IdintPublicTeaNo教师编号stringPublicTeaName教师姓名stringpublicSex性别stringPublicBirthDate出生日期DateTimePublicDegree学历stringPublicRank职称
15、StringPublicTeaTel电话号码stringPublicTeaAddress住址stringPublicRemark备注stringPublicType删除标识intPublic当标识为0时表示该教师已被删除5。4班级模型设计Class名称中文名称类型控制域说明ClassId班级IdintPublicClassNo班级编号stringPublicClassName班级名称stringPublicRemark备注String PublicType删除标识intPublic当标识为0时表示该班级已被删除5.5成绩模型设计Score名称中文名称类型控制域说明ScoreId成绩IdintP
16、ublicCourseId课程IdintPublicStuId学生IdintPublicScore分数floatPublicRemark备注stringPublicType删除标识intPublic当标识为0时表示该班级已被删除5。6课程模型设计Course名称中文名称类型控制域说明CourseId课程IdintpublicCourseNo课程编号stringPublicCourseName课程名称stringPublicPoints学分decPublicRemark备注textPublicType删除标识intPublic当标识为0时表示该课程已被删除6功能类设计命名空间类名说明Manage
17、Login系统功能类Users用户管理功能类Student学生功能类Teacher教师功能类Class班级功能类Score成绩功能类Course课程功能类Class_Course班级课程Class_Teacher教师班级Course_Teacher教师课程6。1用户登录功能类用户登录验证方法:public int JudgeExist(Model。User。Users objUsers, out string strErr)Model.User。Users objUsers为模型类,接收用户的账号和密码及权限信息,执行后返回值0和1,当验证失败时返回0,并用out string输出错误原因;当
18、验证成功时返回1,out stErr为空。6.2用户管理功能类Model。User是Model命名空间下的User类。1.修改用户密码的方法:public int ModifyUser(string UserName , Model.Users.Users objUsers, out string strErr)string UserName是定义接收用户名的变量,根据用户名查找用户,Model。Users.Users objUsers是模型类,得到用户的新密码,out string strErr 定义捕获错误的变量,当返回值为1则修改成功,返回值为0 ,则出错,将错误赋给strErr 2。查
19、询的方法:查询所有记录public int SearchUser(out DataTable objDataTable,out string strErr)out DataTable objDataTable定义了一个表,out string strErr 定义捕获错误的变量,当返回值为1则查询成功,定义的表显示查询结果,返回值为0 ,则出错,将错误赋给strErr查询某行记录public int SearchUser(string UserName,out DataTable objDataTable, out string strErr)string UserName 是定义接收用户名的变
20、量,根据用户名查找用户的相关信息,out DataTable objDataTable定义了一个表,out string strErr 定义捕获错误的变量,当返回值为1则查询成功,定义的表显示查询结果,返回值为0 ,则出错,将错误赋给strErr5。方法列表:方法名传入参数输出返回值类型描述ModifyUserobjUserstrErrint修改SearchUserobjUserobjDataTable,strErrint查询6。3学生信息管理功能类1 添加的方法:public int AddStu( Model。student.student objStu,out string strErr
21、)Model。student。student objStu 是模型类, out string strErr定义捕获错误的变量,int 为1则添加成功,同时添加用户成功,模型类存储学生的相关信息,为0则返回错误提示,将错误赋给strErr2 修改的方法: public int ModifyStu(int iStuId, string strOld, Model。student。student objStu, out string strErr) int iStuId,是传入的学生ID, string strOld是传入的旧的学生编号, Model。student.student objStu 是
22、模型类, out string strErr定义捕获错误的变量int 为1则修改成功,同时修改用户成功,模型类存储学生的相关信息,为0则返回错误提示,将错误赋给strErr3 查询的方法:public int SearchStu(out DataTable objDataTable, out string strErr, string strErr)out DataTable objDataTable定义了一个表,out string strErr 定义捕获错误的变量,当返回值为1则查询成功,定义的表显示查询结果,返回值为0 ,则出错,将错误赋给strErr。public int Search
23、Stu(string strStuNo,string StuName,string ClassName, out DataTable objDataTable, out string strErr) 管理员根据学生编号、学生姓名、学生所在班级进行查询,string strStuNo定义接收学生编号的变量,string StuName定义接收学生姓名的变量,string ClassName定义接收学生所在班级的变量, out DataTable objDataTable定义了一个表,out string strErr 定义捕获错误的变量,当返回值为1时,根据传入的学生编号和学生姓名和所在班级查询
24、学生成功,将查询结果给表,返回值为0,则将错误赋给strErr。4 删除的方法:public int DelStu(int iStuId, string strStuNo, out string strErr)删除学生和账号,int iStuId定义接收学生ID的变量, string strStuNo是定义接收学生编号的变量, out string strErr定义捕获错误的变量,当返回值为1时,删除成功,当返回值为0时,出错,则将错误赋给strErr。5、方法列表:方法名传入参数输出返回值类型描述AddStuobjStustrErrint增加ModifyStuobjStustrErrint修
25、改SearchStustrkeyobjDataTable,strErrint查询DelStuidstrErrint删除6.4教师信息管理功能类1 添加的方法:public int AddTea(Model。teacher.teacher objTea, out string strErr) Model.teacher.teacher objTea是模型类, out string strErr定义捕获错误的变量,int 为1则添加成功,同时添加用户成功,模型类存储教师的相关信息,为0则返回错误提示,将错误赋给strErr2 修改的方法: public int ModifyTea(int iTea
26、Id, string strOld, Model。teacher。teacher objTea, out string strErr) int iTeaId是传入的教师ID, string strOld是传入的旧的教师编号,Model。teacher.teacher objTea是模型类, out string strErr定义捕获错误的变量int 为1则修改成功,同时修改用户成功,模型类存储教师的相关信息,为0则返回错误提示,将错误赋给strErr。3 查询的方法:public int SearchTea (out DataTable objDataTable ,out string str
27、Err) out DataTable objDataTable定义了一个表,out string strErr 定义捕获错误的变量,当返回值为1则查询成功,定义的表显示查询结果,返回值为0 ,则出错,将错误赋给strErr.public int SearchTea(string strTeaNo, string strTeaName, out DataTable objDataTable, out string strErr) 根据教师编号、教师姓名进行查询,string strTeaNo定义接收教师编号的变量,string strTeaName定义接收教师姓名的变量, out DataTab
28、le objDataTable定义了一个表,out string strErr 定义捕获错误的变量,当返回值为1时,根据传入的教师编号和教师姓名查询成功,将查询结果给表,返回值为0,则将错误赋给strErr4删除的方法 public int DelTea(int iTeaId, string strTeaNo, out string strErr)删除教师和账号,int iTeaId定义接收教师ID的变量, string strTeaNo是定义接收教师编号的变量, out string strErr定义捕获错误的变量,当返回值为1时,删除成功,当返回值为0时,出错,则将错误赋给strErr。5
29、 教师职务管理a)添加的方法 public int AddTeacherC_C(Model。Teacher_Course.Teacher_Course objTeacherCourse, Model。Teacher_Class。Teacher_Class objTClass, out string strErr) Model.Teacher_Course。Teacher_Course objTeacherCourse, Model.Teacher_Class.Teacher_Class objTClass Model。teacher.teacher objTea是模型类, out string
30、 strErr定义捕获错误的变量,int 为1则添加成功,模型类存储教师可和教师课程班级以及课程班级的相关信息,为0则返回错误提示,将错误赋给strErrb)查询的方法 public int SearchTCC(out DataTable objDataTable, out string strErr) out DataTable objDataTable定义了一个表,out string strErr 定义捕获错误的变量,当返回值为1则查询成功,定义的表显示查询结果,返回值为0 ,则出错,将错误赋给strErr.public int SearchTCC1(string TeaNo,strin
31、g TeaName ,string CourseName,string ClassName,out DataTable objDataTable, out string strErr) 根据教师编号、教师姓名,课程名称,班级名称进行查询,string TeaNo定义接收教师编号的变量,string TeaName定义接收教师姓名的变量, string ClassName定义了接收班级名称的变量, string CourseName定义了接收课程名称的变量,out DataTable objDataTable定义了一个表,out string strErr 定义捕获错误的变量,当返回值为1时,根
32、据传入的教师编号、教师姓名、课程姓名、班级姓名查询成功,将查询结果给表,返回值为0,则将错误赋给strErr。c)删除的方法public int DelTCC(string TeaNo, string ClassName, string CourseName, out string strErr) 删除教师职务信息, string TeaNo是定义接收教师编号的变量, string ClassName定义了接收班级名称的变量, string CourseName定义了接收课程名称的变量, out string strErr定义捕获错误的变量,当返回值为1时,删除成功,当返回值为0时,出错,则将
33、错误赋给strErrd) 修改的方法public int ModifyTCC(string TeaNo,int OldClassid,int OldCourseid, Model。Teacher_Class.Teacher_Class objTCl, Model。Teacher_Course。Teacher_Course objTCo, out string strErr)修改教师所教班级,string TeaNo定义接收教师编号的变量,int OldClassid定义接收旧的班级ID的变量,int OldCourseid定义接收旧的课程ID的变量, Model。Teacher_Course.
34、Teacher_Course objTCo, Model。Teacher_Class.Teacher_Class objTCl, Model.teacher.teacher objTea是模型类, out string strErr定义捕获错误的变量,返回值 为1则添加成功,模型类存储教师和教师课程班级以及课程班级的相关信息,为0则返回错误提示,将错误赋给strErr. public int ModifyTCC1(string TeaNo,int OldClassid,int OldCourseid, Model.Teacher_Class。Teacher_Class objTCl, Mode
35、l。Teacher_Course。Teacher_Course objTCo, out string strErr) 修改教师所教课程,string TeaNo定义接收教师编号的变量,int OldClassid定义接收旧的班级ID的变量,int OldCourseid定义接收旧的课程ID的变量, Model。Teacher_Course。Teacher_Course objTCo, Model。Teacher_Class。Teacher_Class objTCl, Model。teacher.teacher objTea是模型类, out string strErr定义捕获错误的变量,返回值
36、 为1则添加成功,模型类存储教师可和教师课程班级以及课程班级的相关信息,为0则返回错误提示,将错误赋给strErr。6、方法列表:方法名传入参数输出返回值类型描述AddTeaobjTeastrErrint增加ModifyTeaobjTearstrErrint修改SearchTeaobjTeaobjDataTable,strErrint查询DelTeaIdstrErrint删除6.5班级管理功能类1 添加的方法:public int AddClass( Model。Class。Class objClass,out string strErr)ModelClass objClass是课程模型类。返
37、回值定义为0和1,当添加失败时,返回0,并用out string strErr输出出错原因;当添加成功时,返回1,out string strErr的输出为空。2 修改的方法: public int ModifyClass(string ClassNo, Model.Class.Class objClass, out string strErr)返回值定义为0和1,当修改失败时,返回0,并用out string strErr输出出错原因;当修改时,返回1,out string strErr的输出为空.string iClassNo定义接受班级编号的变量, Model。Class。Class o
38、bjClass为模型类3 查询的方法:查询单行(按班级名和班级编号):public int SearchClass(string ClassNo ,string ClassName, out DataTable objDataTable, out string strErr)string iClassNo定义接受班级编号的变量, string strClassName定义接受班级名称的变量,out DataTable objDataTable是输出内存中的表的内容,用返回值定义为0和1判断查询成功或失败,查询失败时用out string strErr输出出错原因,成功时out string s
39、trErr输出为空。4删除班级public int DelClass(string ClassNo, out string strErr)删除班级信息以及班级中的学生,班级课程表,教师班级表中相应记录string iClassNo定义接受班级编号的变量, out string strErr输出出错原因,成功时out string strErr输出为空。4、方法列表:方法名传入参数输出返回值类型描述AddClassobjClassIdstrErrint增加ModifyClassobjClassIdstrErrint修改SearchClassobjClassIdobjDataTable,strEr
40、rint查询6。6成绩管理功能类1 添加的方法:public int AddScore(Model.Score objScore,out string strErr)Model。Score objScore是课程模型类。返回值定义为0和1,当添加失败时,返回0,并用out string strErr输出出错原因;当添加成功时,返回1,out string strErr的输出为空。2 修改的方法:public intModifyScore(string CourseNo,Model.string StuNo,float Score,out string strErr) 返回值定义为0和1,当添加
41、失败时,返回0,并用out string strErr输出出错原因;当修改成功时,返回1,out string strErr的输出为空,string CourseNo定义了接收课程编号的变量,string StuNo定义接收学生编号的变量,float Scoure 分数变量.3 查询的方法:public intSearchScore(Model.Score objScore,out DataTable objDataTable ,out string strErr)查询所有成绩Model.Score objScore是课程模型类.返回值定义为0和1,当添加失败时,返回0,并用out strin
42、g strErr输出出错原因;当查询成功时,返回1,out string strErr的输出为空。public intSearchScoreStudent(sting StuNo, string TeaNo,string CourseName, string ClassName, Model.Score objScore,out DataTable objDataTable ,out string strErr)按学生、班级、课程、教师查询成绩sting StuNo定义了接收学生编号的变量, string TeaNo接收教师编号,string CourseName,接收课程名称 string
43、ClassName接收班级名称,Model。Score objScore是课程模型类。返回值int定义为0和1,当添加失败时,返回0,并用out string strErr输出出错原因;当查询成功时,返回1,out string strErr的输出为空。4 删除的方法:public int DelScore(int id,out string strErr)int id定义编号, out string strErr输出出错原因,成功时out string strErr输出为空。5. 方法列表:方法名传入参数输出返回值类型描述AddScoreobjScorestrErrint增加ModifySc
44、oreobjScorestrErrint修改SearchScoreClassobjScoreobjDataTable,strErrint查询SearchScoreStudentobjScoreobjDataTable,strErrint查询SearchScoreTeacherobjScoreobjDataTable,strErrint查询DelScoreidstrErrint删除6.7课程信息管理功能类1.添加的方法:public int AddCourse(Model.Course。Course objCourse, out string strErr)Model.Course objCourse是课程模型类.返回值定义为0和1,当添加失败时,返回0,并用out string strErr输出出错原因;当添加成功时,返回1,out string strErr的输出为空。2。修改的方法: public int ModifyCourse(int iCourseId, Model.Course。Course objCourse, out string strErr)返回值定义为0和1,当修改时,返回0,并用out string strErr输出出错原因;当修改时,返回1,out stri