网上选课系统项目报告.doc
《网上选课系统项目报告.doc》由会员分享,可在线阅读,更多相关《网上选课系统项目报告.doc(27页珍藏版)》请在咨信网上搜索。
网上选课系统项目报告 目录 第一章 需求分析 4 1.1概念分析 4 1.2系统分析 5 1.2.1学生选课子系统页面设计 5 1.2.2 教师管理子系统界面设计 5 1.2.3.管理员管理子系统界面设计 5 1.3功能分析 6 1.3.1功能模块图设计 6 1.4用例图设计 6 1.4.1学生用例图设计 6 1.4.2教师用例图设计 7 1.4.3管理员用例图设计 7 第二章 系统设计 7 2.1总体设计 8 2.2数据库设计 8 2.2.1部门表设计 8 2.2.2专业表设计 9 2.2.3班级表设计 9 2.2.4学期表设计 9 2.2.6教师表设计 10 2.2.7学生表设计 10 2.2.9课程表设计 11 2.2.10教师课程关系表设计 11 2.3表间关系图 12 2.3.1UV_Base_Major 12 2.3.2UV_Base_Class 12 2.3.4UV_Select_TeacheSubjectReleation 13 2.3.5UV_Select_StudenSubjectReleation 13 2.3.6UV_Select_SelectSubjectVerify 14 第三章 程序设计 14 3.1网上选课系统后台程序实现 14 3.1.1母版页设计 14 3.1.2基本信息管理页面设计 15 3.2网上选课系统前台程序实现 16 3.2.1系统注册页面设计 16 3.2.2学生选课页面设计 16 3.2.3教师任务查看页面设计 17 第四章 编码设计 17 4.1班级管理的编码 17 4.2专业管理的编码 19 4.3课程管理的编码 20 4.4学期管理的编码 21 第五章 编码测试 23 5.1页面测试 23 5.2数据表测试 23 第六章 部署维护 24 1. 24 2. 24 3. 24 4. 24 5. 25 6. 25 7. 26 第一章 需求分析 1.1概念分析 学生网上选课系统用于根据教学计划、教师资源等,制定每学期的课程表及相关信息,面对的用户包括系统管理员、教师和学生。因此该系统的功能模块应分为系统姑那里远需求、教师需求、学生需求三个部分。管理员可以通过超级用户身份登录,对系统进行全面的管理维护,老师、学生以不同用户的身份进入不同的界面,执行不同的操作。 该系统为学生主要提供选课服务,因此学生可以直接查看选课情况,学生可以根据本人学号和密码登陆系统,进行相关操作。此外还应附带其他服务,如实核对个人信息,查看教师信息、课程信息以便选课,查看自己选课结果,查询考试成绩等。 查询的功能需求: (1)说明:此功能是学生可以查询本学期的开课计划,包括课程的详细信息,专业课查询,选修课查询,已选课查询等。 (2)录入:通过友好的交互界面,使学生通过点击鼠标就可以实现各种查询功能。 (3)加工:系统通过点击鼠标所提交的查询请求,利用数据系统的查询功能查询出符合要求的记录。 (4)输出:在屏幕上显示查询后的结果,通常以 报表的形式显示。 1.2系统分析 1.2.1学生选课子系统页面设计 客户端可以为学生提供网上选课的过程,学生通过选择身份登录,进入选课系统,然后进行选课,提交的选课结果传到服务器端,便于接下来的教师打分。教师打完分数后,学生登录后可以查询个人或其他人的成绩。首先进入选择登录身份界面,点击“登录”之后进入选择操作界面,包括“选修”“查看选课结果”、“查询成绩”。 1.2.2 教师管理子系统界面设计 客户端可以为教师提供网上查看学生选课信息、打分、统计的过程,教师通过选择身份登录,进入选课系统,然后进行学生选课信息,为学生打分,提交的分数传到服务器端,便于接下来的学生查询分数。首先进入选择登录身份界面,点击“登录”之后进入选择操作界面,包括“学生选课信息”、“打分”、“统计”。 1.2.3.管理员管理子系统界面设计 客户端有为教师提供网上管理学生、管理教师、管理课程的过程,管理员通过选择身份登录,进入选课系统,然后可以选择学生管理,管理教师或管理课程,管理员的请求被提交到服务器端,满足用户的要求。首先进入选择登录身份界面,点击“登录”之后进入选择操作界面,包括“管理学生”“管理教师”、“管理课程”。 1.3功能分析 1.3.1功能模块图设计 1.4用例图设计 1.4.1学生用例图设计 1.4.2教师用例图设计 1.4.3管理员用例图设计 第二章 系统设计 2.1总体设计 2.2数据库设计 2.2.1部门表设计 2.2.2专业表设计 2.2.3班级表设计 2.2.4学期表设计 2.2.5职称表设计 2.2.6教师表设计 2.2.7学生表设计 2.2.8课程类型表设计 2.2.9课程表设计 2.2.10教师课程关系表设计 2.2.11学生课程关系表设计 2.3表间关系图 2.3.1UV_Base_Major 2.3.2UV_Base_Class 2.3.3UV_Base_ Subject 2.3.4UV_Select_TeacheSubjectReleation 2.3.5UV_Select_StudenSubjectReleation 2.3.6UV_Select_SelectSubjectVerify 第三章 程序设计 3.1网上选课系统后台程序实现 3.1.1母版页设计 3.1.2基本信息管理页面设计 3.1.3教学任务分配设计 3.2网上选课系统前台程序实现 3.2.1系统注册页面设计 3.2.2学生选课页面设计 3.2.3教师任务查看页面设计 第四章 编码设计 4.1班级管理的编码 public partial class Admin_SelectSubject_ClassManage : System.Web.UI.Page { private string sql = ""; protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) InitPageData(); } private void InitPageData() { String operFlag = Request.QueryString["operFlag"]; if (operFlag == null) operFlag = "add"; if ("modify".Equals(operFlag)) { String classID = Request.QueryString["ID"]; sql = "SELECT ID,MajorID,ClassNo,ClassName,Remark FROM UT_Base_Class where ID=" + classID; DataTable dtClass = CommonUtils.GetTableBySql(sql).Copy(); txtNo.Text = Convert.ToString(dtClass.Rows[0]["classNo"]); txtName.Text = Convert.ToString(dtClass.Rows[0]["className"]); ddlMajor.SelectedValue = Convert.ToString(dtClass.Rows[0]["majorID"]); txtRemark.Text = Convert.ToString(dtClass.Rows[0]["Remark"]); Session.Add(CommonUtils.Session_ClassID, dtClass.Rows[0]["ID"]); btnAdd.Visible = false; btnModify.Visible = true; btnQuery.Visible = false; } else { btnAdd.Visible = true; btnModify.Visible = false; btnQuery.Visible = true; } sql = "SELECT ID,ClassNo,ClassName,MajorName,DepartName FROM UV_Base_Class where 1=1 "; CommonUtils.ECGridView(gdvClass, sql); sql = "select ID,majorName from ut_base_major"; CommonUtils.ECDropDownList(ddlMajor, sql, "majorName", "ID", true); } protected void btnQuery_Click(object sender, EventArgs e) { sql = "SELECT ID,ClassNo,ClassName,MajorName,DepartName FROM UV_Base_Class where 1=1 "; String tmp = ""; tmp = txtNo.Text.Trim(); if (!"".Equals(tmp)) sql += " and classNo='" + tmp + "'"; tmp = txtName.Text.Trim(); if (!"".Equals(tmp)) sql += " and className like '%" + tmp + "%'"; tmp = txtRemark.Text.Trim(); if (!"".Equals(tmp)) sql += " and classRemark like '%" + tmp + "%'"; tmp = ddlMajor.SelectedValue; if (!tmp.Equals(CommonUtils.DDL_First_Item_Value)) sql += " and MajorID='" + tmp + "'"; CommonUtils.ECGridView(gdvClass, sql); } protected void btnAdd_Click(object sender, EventArgs e) { sql = "insert into UT_Base_Class (MajorID,ClassNo,ClassName,Remark ) values("; sql += ddlMajor.SelectedValue + ",'"; sql += txtNo.Text.Trim() + "','"; sql += txtName.Text.Trim() + "','"; sql += txtRemark.Text.Trim() + "')"; int result = CommonUtils.OperateData(sql); if (result == 1) Response.Write("<script language='javascript'>alert('班级添加成功!');</script>"); else Response.Write("<script language='javascript'>alert('班级添加失败!');</script>"); } protected void btnModify_Click(object sender, EventArgs e) { sql = "update UT_Base_Class set "; sql += "MajorID=" + ddlMajor.SelectedValue + ","; sql += "ClassNo='" + txtNo.Text.Trim() + "',"; sql += "ClassName='" + txtName.Text.Trim() + "',"; sql += "Remark='" + txtRemark.Text.Trim() + "'"; sql += " where ID=" + Convert.ToString(Session[CommonUtils.Session_ClassID]); Session.Remove(CommonUtils.Session_ClassID); int result = CommonUtils.OperateData(sql); if (result == 1) Response.Write("<script language='javascript'>alert('班级信息修改成功!');</script>"); else Response.Write("<script language='javascript'>alert('班级信息修改失败!');</script>"); } protected void btnDel_Click(object sender, EventArgs e) { int count = 0; for (int i = 0; i < gdvClass.Rows.Count; i++) { CheckBox cbx = (CheckBox)this.gdvClass.Rows[i].FindControl("cbxDelOper"); if (cbx.Checked == true) { Label lblClassID = (Label)this.gdvClass.Rows[i].FindControl("lblClassID"); string classID = lblClassID.Text; sql = "delete from UT_Base_Class where ID=" + classID; int count1 = CommonUtils.OperateData(sql); if (count1 != 0) count++; } } Response.Write("<script language='javascript'>alert('共删除" + count + "个班级');</script>"); InitPageData(); } protected void gdvClass_PageIndexChanging(object sender, GridViewPageEventArgs e) { gdvClass.PageIndex = e.NewPageIndex; InitPageData(); } protected void txtNo_TextChanged(object sender, EventArgs e) { string classNo = txtNo.Text.Trim(); sql = "select count(*) from UT_Base_Class where ClassNo='" + classNo + "'"; bool isExist = false; int result = Convert.ToInt32(CommonUtils.GetScalarBySql(sql)); if (result > 0) isExist = true; if (isExist) { this.lblClassExist.Visible = true; this.txtNo.Focus();// } else { this.lblClassExist.Visible = false; this.txtName.Focus(); } } } 4.2专业管理的编码 public partial class Admin_SelectSubject_MajorManage : System.Web.UI.Page { String sql = ""; protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { InitPageData(); } } private void InitPageData() { sql = "SELECT ID,DepartmentID,MajorNo,MajorName,DepartNo,DepartName,ParentID,DepartRemark FROM UV_Base_Major"; CommonUtils.ECGridView(this.gdvMajor, sql); sql = "SELECT ID,DepartNo,DepartName,ParentID,Remark FROM UT_Base_Department"; CommonUtils.ECDropDownList(this.ddlDepartment, sql, "DepartName", "ID", true); } protected void gdvMajor_PageIndexChanging(object sender, GridViewPageEventArgs e) { this.gdvMajor.PageIndex = e.NewPageIndex; InitPageData(); } protected void btnAdd_Click(object sender, EventArgs e) { string majorNo = this.txtMajorNo.Text.Trim(); string majorName = this.txtMajorName.Text.Trim(); string remark = this.txtMajorRemark.Text.Trim(); string departmentID = this.ddlDepartment.SelectedValue; sql = "insert into UT_Base_Major(DepartmentID,MajorNo,MajorName,Remark) values(" + departmentID + ",'" + majorNo + "','" + majorName + "','" + remark + "')"; int result = CommonUtils.OperateData(sql); if (result == 1) Response.Write("<script language='javascript'>alert('专业添加成功!');</script>"); else Response.Write("<script language='javascript'>alert('专业添加失败!');</script>"); InitPageData(); } } 4.3课程管理的编码 public partial class Admin_SelectSubject_SubjectManage : System.Web.UI.Page { private string sql = ""; protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { InitPageData(); } } private void InitPageData() { sql = "SELECT ID,DepartNo,DepartName,ParentID,Remark FROM UT_Base_Department"; CommonUtils.ECDropDownList(ddlDepartment, sql, "DepartName", "ID", true); sql = "SELECT ID,StartYear,EndYear,TermOrder FROM UT_Base_Term"; DataTable dt = CommonUtils.GetTableBySql(sql).Copy(); for (int i = 0; i < dt.Rows.Count; i++) { DataRow dr = dt.Rows[i]; dr["StartYear"] = Convert.ToString(dr["StartYear"]) + "-" + Convert.ToString(dr["EndYear"]) + "学年 第" + Convert.ToString(dr["TermOrder"]) + "学期"; } CommonUtils.Dt2DropDownList(ddlTerm, dt, "StartYear", "ID", true); } protected void btnQuery_Click(object sender, EventArgs e) { sql = " SELECT * "; sql += " FROM UV_Base_Subject "; sql += " where 1=1 "; string tmp = ""; tmp = this.txtSubjectNo.Text.Trim(); if (!"".Equals(tmp)) sql += " and SubjectNo='" + tmp + "'"; tmp = this.txtSubjectName.Text.Trim(); if (!"".Equals(tmp)) sql += " and SubjectName like '%" + tmp + "%'"; tmp = this.ddlTerm.SelectedValue; if (!"0".Equals(tmp)) sql += " and TermID=" + tmp; tmp = this.ddlDepartment.SelectedValue; if (!"0".Equals(tmp)) sql += " and DepartmentID=" + tmp; DataTable dt = CommonUtils.GetTableBySql(sql).Copy(); for (int i = 0; i < dt.Rows.Count; i++) { DataRow dr = dt.Rows[i]; dr["StartYear"] = Convert.ToString(dr["StartYear"]) + "-" + Convert.ToString(dr["EndYear"]) + "学年 第" + Convert.ToString(dr["TermOrder"]) + "学期"; } this.gdvSubject.DataSource = dt.DefaultView; this.gdvSubject.DataBind(); } protected void gdvSubject_PageIndexChanging(object sender, GridViewPageEventArgs e) { this.gdvSubject.PageIndex = e.NewPageIndex; InitPageData(); } protected void btnDel_Click(object sender, EventArgs e) { int count = 0; for (int i = 0; i < this.gdvSubject.Rows.Count; i++) { CheckBox cbx = (CheckBox)this.gdvSubject.Rows[i].FindControl("cbxDelOper"); if (cbx.Checked == true) { Label lblSubjectID = (Label)this.gdvSubject.Rows[i].FindControl("lblSubjectID"); string subjectId = lblSubjectID.Text; sql = "delete from UT_Base_Subject where ID=" + subjectId; int count1 = CommonUtils.OperateData(sql); if (count1 != 0) count++; } } Response.Write("<script language='javascript'>alert('共删除" + count + "门课程');</script>"); InitPageData(); } } 4.4学期管理的编码 public partial class Admin_SelectSubject_TermManage : System.Web.UI.Page { String sql = ""; protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { InitPageData(); } } private void InitPageData() { sql = "SELECT ID,StartYear,EndYear,termOrder FROM UT_Base_Term"; CommonUtils.ECGridView(this.gdvTerm, sql); Lb_PageInfo.Text = "第" + (gdvTerm.PageIndex + 1).ToString() + "页 / 共 " + gdvTerm.PageCount + " 页"; } protected void gdvTerm_PageIndexChanging(object sender, GridViewPageEventArgs e) { this.gdvTerm.PageIndex = e.NewPageIndex; int x = Convert.ToInt32(e.NewPageIndex) + 1; InitPageData(); } protected void btnAdd_Click(object sender, EventArgs e) { string startYear = this.ddlYear.SelectedValue.Substring(0, 4); string endYear = this.ddlYear.SelectedValue.Substring(this.ddlYear.SelectedValue.IndexOf("-") + 1); string termOrder = this.ddlTerm.SelectedValue; sql = "insert into UT_Base_Term(StartYear,EndYear,TermOrder) values('" + startYear + "','" + endYear + "'," + termOrder + ")"; int result = CommonUtils.OperateData(sql); if (result == 1) Response.Write("<script language='javascript'>alert('学期添加成功!');</script>"); else Response.Write("<script language='javascript'>alert('学期添加失败!');</script>"); InitPageData(); } protected void gdvTerm_RowDeleting(object sender, GridViewDeleteEventArgs e) { string id = gdvTerm.DataKeys[e.RowIndex].Value.ToString(); sql = "delete UT_Base_Term where ID='" + id + "'"; int result = CommonUtils.OperateData(sql); if (result == 1) Response.Write("<script language='javascript'>alert('学期删除成功!');</script>"); else Response.Write("<script language='javascript'>alert('学期删除失败!');</script>"); InitPageData(); } protected void gdvTerm_RowDataBound(object sender, GridViewRowEventArgs e) { if (e.Row.RowType == DataControlRowType.DataRow) { if (e.Row.RowState == DataControlRowState.Normal || e.Row.RowState == DataControlRowState.Alternate) { ((LinkButton)e.Row.Cells[5].Controls[0]).Attributes.Add("- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 网上 选课 系统 项目 报告
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文