欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    数据库课程设计之学生信息管理系统.doc

    • 资源ID:17609301       资源大小:351.50KB        全文页数:13页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    数据库课程设计之学生信息管理系统.doc

    【精品文档】如有侵权,请联系网站删除,仅供学习与交流数据库课程设计之学生信息管理系统.精品文档.一、引言1课程实验目的课程设计为学生提供了一个既动手又动脑,独立实践的机会,将课本上的理论知识和实际有机的结合起来,锻炼学生的分析解决实际问题的能力。提高学生适应实际,实践编程的能力。课程设计的目的:· 加深对数据库系统、软件工程、程序设计语言的理论知识的理解和应用水平;· 在理论和实验教学基础上进一步巩固已学基本理论及应用知识并加以综合提高;· 学会将知识应用于实际的方法,提高分析和解决问题的能力,增强动手能力;· 为毕业设计和以后工作打下必要基础。2 课程实验题目:设计一个大学教学数据库应用。该系统涉及学生、教师、课程、分组、登记、数据。3 课程设计要求:运用数据库基本理论与应用知识,在微机RDBMS(SQL Server)的环境上建立一个数据库应用系统。要求把现实世界的事物及事物之间的复杂关系抽象为信息世界的实体及实体之间联系的信息模型,再转换为机器世界的数据模型和数据文件,并对数据文件实施检索、更新和控制等操作。1. 用E-R图设计指定题目的信息模型;2. 设计相应的关系模型,确定数据库结构;3. 分析关系模式各属于第几范式,阐明理由;4. 设计应用系统的系统结构图,确定系统功能;5. 使用对象许可和命令许可、角色控制设计安全性控制检查程序;6. 通过设计关系的主码约束、外码约束和使用CHECK、RULE实现完整性控制;7. 为每一参照关系设计插入、删除、修改触发器;8. 实现应用程序设计、编程、优化功能;9. 对系统的各个应用程序进行集成和调试,进一步优化系统功能、改善系统用户界面完成实验内容所指定的各项要求;10. 分析遇到的问题,总结并写出课程设计报告;11. 自我评价二、 用E-R图设计选定题目的信息模型 学生实体的E-R图cityzipaddressStudent_namestatestudentsexSTUDENTS 教师实体E-R图phoneTeacher_namesalaryteacherTEACHERS 课程实体E-R图departmentnurc_creditsCourse_namecourseCOURSES 分组实体E-R图teachersectionnum_studentscourseSECTIONS 教师任课实体E-R图sectiongradestudentcourseENROLLS 三、设计相应的关系模型,确定数据库结构* STUDENTS(student,student_name,address,zip,city,state,sex)* TEACHERS(teacher,teacher_name,phone,salary)* COURSES(course,course_name,department,nurc_credits)* SECTION(section,teacher,course,num_students)* ENROLLS(course,section,student,grade)· 分析关系模式各属于第几范式,阐明理由;STUDENTS 属于BCNF,因为其中的每个决定因素都包含了码TEACHERS 属于BCNF,因为其中的每个决定因素都包含了码COURSES 属于BCNF,因为其中的每个决定因素都包含了码ENROLLS 属于BCNF,因为其中的每个决定因素都包含了码SECTION 属于BCNF, 因为其中的每个决定因素都包含了码 · 设计关系的主码约束、外码约束和使用CHECK实现完整性控制; STUDENTS信息基本表 create table STUDENTS( student char(8) primary key, student_name char(20), address char(20), zip char(10), city char(20), state char(8), sex char(2); TEACHERS基本表 create table TEACHERS( teacher char(8) primary key, teacher_name char(10), phone char(10), salary char(8); COURSES基本表 create table COURSES( course char(8) primary key, course_name char(20), department char(20), nurc_credits char(4); SECTION表 create table SECTION( section char(4), teacher char(8) primary key, course char(8), num_students char(4), foreign key (course) references COURSES(course); ENROLLS表 create table ENROLLS( course char(8), section char(4), student char(8), grade SMALLINT, primary key(course,section,student), foreign key (course) references COURSES(course), foreign key (student) references STUDENTS(student);· 为参照关系设计插入、删除、修改触发器;· 实现应用程序设计、编程、优化功能;· 对系统的各个应用程序进行集成和调试,进一步优化系统功能、改善系统用户界面完成实验内容所指定的各项要求;四、源程序代码清单using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using System.Data.SqlClient;namespace WindowsFormsApplication2 public partial class Form1 : Form public Form1() InitializeComponent(); private void 学生ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select* from STUDENTS", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "STUDENTS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /学生基本信息 private void 教师ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select* from TEACHERS", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "TEACHERS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /教师基本信息 private void 课程ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select* from COURSES", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "COURSES"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /课程基本信息 private void 分组ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select* from SECTION", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "SECTION"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /分组基本信息 private void 登记ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select* from ENROLLS", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "ENROLLS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /登记基本信息 private void 查询1 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select* from COURSES where department IN('Math','English')", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "COURSES"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索系名为“Math”和“English”的课程表信息 private void 查询2 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select teacher_name,phone from TEACHERS order by teacher_name", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "TEACHERS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /按字母顺序列出教师姓名和电话号码 private void 查询3 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select teacher_name,phone from TEACHERS where phone not like '257%'", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "TEACHERS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索电话号码不是以“257”打头的教师姓名和电话号码 private void 查询4 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select course_name,department,nurc_credits from COURSES where department='Math' and nurc_credits>'3'", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "COURSES"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索数学系所有成绩大于3的课程名、系名、学分 private void 查询5 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select student_name,student from STUDENTS where not exists (select* from ENROLLS where STUDENTS.student=ENROLLS.student)", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "STUDENTS,ENROLLS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索没有选修任何课的学生姓名、学号 private void 查询6 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select student from STUDENTS where not exists (select* from ENROLLS,COURSES where STUDENTS.student=ENROLLS.student and COURSES.course=ENROLLS.course and course_name='Calculus Iv')", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "STUDENTS,ENROLLS,COURSES"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索没有选修课程“Calculus Iv”的学生学号 private void 查询7 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select distinct student from ENROLLS A where not exists (select* from TEACHERS where teacher_name='Dr.Lowe' and not exists (select * from ENROLLS B where B.course=A.course)", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "TEACHERS,ENROLLS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索至少选修教师“Dr. Lowe”所开全部课程的学生学号 private void 查询8 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select COURSES.course,count(num_students),COURSES.course_name from SECTION,COURSES where COURSES.course=SECTION.course group by COURSES.course_name,COURSES.course ", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "COURSES,SECTION"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索每门课学生登记的人数、相应的课程名、课程号、分组号 private void 查询9 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select student_name from STUDENTS where student in(select student from ENROLLS group by student having count(*)>2 )", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "STUDENTS,ENROLLS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索选修两门以上课程的学生姓名 private void 查询10 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select distinct course,student_name from STUDENTS,ENROLLS where ENROLLS.student=STUDENTS.student and sex='M'", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "STUDENTS,ENROLLS"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索只有男生选修的课程和学生名 private void 查询11 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select STUDENTS.student_name,COURSES.course_name,TEACHERS.teacher_name,ENROLLS.grade from COURSES,STUDENTS,TEACHERS,ENROLLS,SECTION where STUDENTS.student=ENROLLS.student and ENROLLS.course=COURSES.course and SECTION.teacher=TEACHERS.teacher and SECTION.course=COURSES.course", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "STUDENTS,ENROLLS,TEACHERS,COURSES,SECTION"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); /检索所有学生选修的课程名、学生名、授课教师名、该生成绩 private void 查询12 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select avg(grade) from COURSES,ENROLLS,TEACHERS,SECTION where COURSES.course=ENROLLS.course and TEACHERS.teacher=SECTION.teacher and course_name='english composition' and teacher_name like '%Engle'", conn); DataSet ds1 = new DataSet(); sdr1.Fill(ds1, "ENROLLS,TEACHERS,COURSES,SECTION"); dataGridView1.DataSource = ds1.Tables0; conn.Close(); / 统计教师“Engle”教的英语课的学生平均分 private void 查询13 ToolStripMenuItem_Click(object sender, EventArgs e) string connectionStr = "Data Source=qinjia-PC;Initial Catalog=sjk;Integrated Security=True" SqlConnection conn = new SqlConnection(connectionStr); conn.Open(); SqlDataAdapter sdr1 = new SqlDataAdapter("select course_name,count(num_students) from COURSES,SECTION where COURSES.course=SECT

    注意事项

    本文(数据库课程设计之学生信息管理系统.doc)为本站会员(豆****)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开